Python学习打call第四十五天:MySQL数据库使用(一)

1.数据库概念

  • 数据库(Database)是按照数据结构来组织、存储和管理数据的仓库;

  • 每个数据库都有一个或多个不同的API用于创建,访问,管理,搜索和复制所保存的数据;

2.常用的数据库分类

  • 关系型数据库有OracleMySQLPostgreSQLSQL ServerDB2等;

  • 非关系型数据库有NoSqlMongoDBCloudantRedisElasticsearchHBase等;

1.png

3.关系型数据库的优缺点

优点:

  • 容易理解,二维表结构是非常贴近逻辑世界一个概念,关系模型相对网状、层次等其他模型来说更容易理解 易于维护,都是使用表结构,格式一致;

  • 使用方便,通用的SQL语言使得操作关系型数据库非常方便;

缺点:

  • 读写性能比较差,尤其是海量数据的高效率读写;

  • 固定的表结构,灵活度不高;

  • 每一步都要进行加锁的操作,增加数据库负担;

  • 不擅长对简单查询需要快速返回结果的处理;

4.非关系型数据库的优缺点

优点:

  • 格式灵活,存储数据的格式可以是key,value形式、文档形式、图片形式等等,文档形式、图片形式等等,使用灵活,应用场景广泛,而关系型数据库则只支持基础类型;

  • 无需经过sql层的解析,读写性能很高;

  • 基于键值对,数据没有耦合性,容易扩展;

缺点:

  • 不提供sql支持,学习和使用成本较高;

  • 无事务处理;

  • 数据结构相对复杂,复杂查询方面稍欠;

5.MySQL数据库的概念

  • MySQL是一种关系型数据库管理软件;

  • 也是Web世界中使用最广泛的数据库服务器;

  • MySQL内部有多种数据库引擎,最常用的引擎是支持数据库事务的InnoDB;

MySQL在过去由于性能高、成本低、可靠性好,已经成为最流行的开源数据库,因此被广泛地应用在Internet上的中小型网站中。随着MySQL的不断成熟,它也逐渐用于更多大规模网站和应用,比如维基百科、Google和Facebook等网站。非常流行的开源软件组合LAMP中的“M”指的就是MySQL。

6.MySQL数据类型

  • 整数:tinyintsmallintmediumintintbigint

  • 浮点数:floatdoublerealdecimal

  • 日期和时间:datetimedatetimetimestampyear

  • 字符串:charvarchar

  • 文本类型:tinytexttextmediumtextlongtext

  • 二进制:tinyblobblobmediumbloblongblob

  • 对数据类型的修饰符:unsignednot nulldefault

7.SQL语句分类

  • DDL:数据库定义语言,负责数据库定义,包括CREATEALTERDROP
# 创建库
create database Student;

# 如果没有Student这个库则创建它,character set指定字符集为utf8, 排序规则为utf8_bin
create datebase if not exists Student character set utf8 collate utf8_bin

# 删除库
drop database Student;

# 修改库
alter database Student character set = utf8mb4
alter database Student collate = utf8mb4_general_ci

# 创建表
create table students (id int not null primary key auto_increment, name varchar(250) not null, class varchar(250) not null) engine=InnoDB default charset=utf8;

# 查看表结构
desc students;

# 修改表
alter table students add gender enum('f','m');
alter table students drop gender;
alter table students change name username varchar(100) after id;
alter table students modify username varchar(100) first;

# 删除表
drop table students;
  • DML:数据库操作语言, 负责数据集对象操作,包括INSERTDELETEUPDATESELECT
# 给students表增加数据
insert into students (class,username) values ('一年级', 'Luky'), ('二年级', 'Tom'), ('三年级', 'Mark');

# 修改students表中id = 1 的字段class的值为“初一”
update students set class = '初一' where id = 1;

# 删除class为一年级的字段
delete from students where class = '一年级';
  • DCL:数据库控制语言, 负责权限访问控,包括GRANTREVOKE
# 先创建用户,再授权
create user Mark@'172.16.19.%' identified by '123456';
grant all on *.* to Mark@'172.16.19.%';
flush privileges;

# 创建用户的同时给用户授权
grant all on *.* to Mark@'172.16.19.%' identified by '123456';
flush privileges;

# 给用户授予某些权限
show grants for Mark@'172.16.19.%';

# 撤销授权
revoke select ON *.* from Mark@'172.16.19.%';
flush privileges;

# 查看用户的权限
show grants for Mark@'172.16.19.%';

# 删除用户
delete from mysql.user where user = "Mark";
flush privileges;

# 删除用户
drop user 'Mark'@'192.168.%.%';

# 修改密码
(1)set password for 'Mark'@'192.168.%.%' = password('123456');
(2)使用update命令,直接修改 mysql.user 用户表,修改之后flush priveleges;
  • TCL:事务控制语言,负责ACID事务处理,包括commit(提交)rollback(回滚)
# SQL删除记录语句
sql = "DELETE FROM Student WHERE AGE > %s" % (30)
try:
    cursor.execute(sql)
    # 向数据库提交
    db.commit()
except:
    # 发生错误时回滚
    db.rollback()
  • SQL语句不区分大小写,句尾使用分号表示一条语句结束, \G 结尾表示以以竖行显示

8.SELECT 语句

SELECT语句处理流程.png
  • 查询表上的所有的数据;
select * from Student
  • 查询部分数据;
select id,name from Student;
  • as给字段取别名,可以给一个字段取,也可以给多个字段取;
select id as num,name from Student;

select id as num,name as username from Student;
  • where子句用于指明过滤条件,可以使用的算数运算符有:+, -, * ,/ ,= ,!= ,<=, >=,连接词有:and , or
select * from Student where id >= 1;
select * from Student where id <= 5 and id >1;
select * from Student where id <3 or id >10;
select * from Student where id between 1 and 5;    # between 较小的数 and 较大的数
  • like语句用于模糊匹配,%表示任意长度的字符,_表示任意单个字符
select * from Student where class like 'Ma%';

select * from Student where class like 'Ma_k';
  • 可以使用null对值进行判断
select * from Student where id is not null;
select * from Student where id is null;

  • group by 子句可以根据指定的查询条件将查询结构进行分组,用于做聚合运算,可以使用的聚合函数:avg()max()min()count()sum()
select age,gender from students group by gender; 
select avg(age),gender from students group by gender; 
select min(age), gender from students group by gender;
select max(age), gender from students group by gender;
select count(id), gender from students group by gender; 
  • 使用order by语句排序,默认是asc,表示升序排列,desc是降序;
select * from Student order by id desc;
  • having子句用于将分组之后的结果再次过滤;
select avg(age) as 'average_age', gender from students group by gender having average_age > 50;
  • limit 子句用于对查询的结果进行输出行数的限制 ;
# 选前5行
select id,name from students order by id desc limit 5; 

# 前4个不选,从第5行开始选2行
select id,name from students order by id limit 4, 2; 
  • 子句的书写顺序:where -> group by -> having -> order by -> limit
select *,avg(score) as '各班平均成绩' from students where id > 1 group by class having avg(score) > 55 order by score desc limit 3 ;

参考:https://www.9xkd.com/user/plan-view.html?id=4200717020

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容

  • 转 # https://www.cnblogs.com/easypass/archive/2010/12/ 08/...
    吕品㗊阅读 9,714评论 0 44
  • MYSQL 基础知识 1 MySQL数据库概要 2 简单MySQL环境 3 数据的存储和获取 4 MySQL基本操...
    Kingtester阅读 7,790评论 5 116
  • MYSQL应该是最流行的WEB后端数据库。大量应用于PHP,Ruby,Python,Java 等Web语言开发项目...
    smooth00阅读 2,275评论 0 16
  • 今天看到一位朋友写的mysql笔记总结,觉得写的很详细很用心,这里转载一下,供大家参考下,也希望大家能关注他原文地...
    信仰与初衷阅读 4,726评论 0 30
  • 2016年的末日《超级厄尔尼诺事件》已经应验,造成全球人道危机。持续时间达7个月,极端天气肆虐全球89个国家...
    宇宙英雄阅读 313评论 0 0