数据库就是一种特殊的文件,其中存储着需要的数据
一:操作数据库
1.1 命令行 连接
1 | mysql -uroot -p |
1.2 查看所有数据库
1 | show databases; |
1.3 使用数据库
1 | use 数据库名; |
1.4 查看当前使用的数据库
1 | select database(); |
1.5 创建数据库
1 | create database 数据库名 charset=utf8; |
1.6 删除数据库
1 | drop database 数据库名; |
二:数据表操作
2.1 查看当前数据库中所有表
1 | show tables; |
2.2 查看表结构
1 | desc 表名; |
2.3 创建表
1 | 例:创建班级表 |
2.4 修改表-添加字段
1 | alter table 表名 add 列名 类型; |
2.5 修改表-修改字段:重命名版
1 | alter table 表名 change 原名 新名 类型及约束; |
2.6 修改表-修改字段:不重命名版
1 | alter table 表名 modify 列名 类型及约束; |
2.7 修改表-删除字段
1 | alter table 表名 drop 列名; |
2.8 删除表
1 | drop table 表名; |
2.9 查看表的创建语句
1 | show create table 表名; |
三 . MySQL 查询
3.1 普通查询
- 查询所有字段
1 | select * from 表名; |
- 查询指定字段
1 | select 列1,列2,... from 表名; |
- 使用 as 给字段起别名
1 | select id as 序号, name as 名字, gender as 性别 from students; |
- 可以通过 as 给表起别名
1 | -- 如果是单表查询 可以省略表明 |
- 在select后面列前使用distinct可以消除重复的行
1 | select distinct 列1,... from 表名; |
3.2 条件查询
使用where子句对表中的数据筛选,结果为true的行会出现在结果集中
- 语法如下:
1 | select * from 表名 where 条件; |
where后面支持多种运算符,进行条件的处理
比较运算符 = > >= < <= != <>
逻辑运算符 and or not
模糊查询 like
%表示任意多个任意字符
_表示一个任意字符
1
select * from students where name like '黄%' or name like '%靖';
范围查询
in表示在一个非连续的范围内
1
select * from students where id in(1,3,8);
between … and …表示在一个连续的范围内
1
select * from students where id between 3 and 8;
空判断 判空is null
1
select * from students where height is null;
优先级
- 优先级由高到低的顺序为:小括号,not,比较运算符,逻辑运算符
3.3 排序查询
为了方便查看数据,可以对数据进行排序
1 | select * from 表名 order by 列1 asc|desc [,列2 asc|desc,...] |
说明
- 将行数据按照列1进行排序,如果某些行列1的值相同时,则按照列2排序,以此类推
- 默认按照列值从小到大排列(asc)
- asc从小到大排列,即升序
- desc从大到小排序,即降序
例:显示所有的学生信息,先按照年龄从大–>小排序,当年龄相同时 按照身高从高–>矮排序
1 | select * from students order by age desc,height desc; |
3.4 聚合函数
count(*)表示计算总行数,括号中写星与列名,结果是相同的
max(列)表示求此列的最大值
min(列)表示求此列的最小值
sum(列)表示求此列的和
avg(列)表示求此列的平均值
1 | select count(*) from students; |
3.5 分组
group by的含义:将查询结果按照1个或多个字段进行分组,字段值相同的为一组
group by + group_concat()
- group_concat(字段名)可以作为一个输出字段来使用,
- 表示分组之后,根据分组结果,使用group_concat()来放置每一组的某字段的值的集合
group by + 集合函数
- 通过group_concat()的启发,我们既然可以统计出每个分组的某字段的值的集合,那么我们也可以通过集合函数来对这个
值的集合
做一些操作
- 通过group_concat()的启发,我们既然可以统计出每个分组的某字段的值的集合,那么我们也可以通过集合函数来对这个
group by + having
- having 条件表达式:用来分组查询后指定一些条件来输出查询结果
- having作用和where一样,但having只能用于group by
group by + with rollup
- with rollup的作用是:在最后新增一行,来记录当前列里所有记录的总和
1 | select gender,group_concat(id) from students group by gender; |
3.6 分页
当数据量过大时,在一页中查看数据是一件非常麻烦的事情
语法
1 | select * from 表名 limit start,count |
说明
- 从start开始,获取count条数据
例1:查询前3行男生信息
1 | select * from students where gender=1 limit 0,3; |
3.7 总结
查询的完整格式 ^_^ 不要被吓到 其实很简单 ! _ !
1 | SELECT select_expr [,select_expr,...] [ |
- 完整的select语句
1 | select distinct * |
- 执行顺序为:
- from 表名
- where ….
- group by …
- select distinct *
- having …
- order by …
- limit start,count
- 实际使用中,只是语句中某些部分的组合,而不是全部
四:python 操作 MYSQL
4.1 引入模块
- 在py文件中引入pymysql模块
1 | from pymysql import * |
4.2 Connection 对象
- 用于建立与数据库的连接
- 创建对象:调用connect()方法
1 | conn=connect(参数列表) |
- 参数host:连接的mysql主机,如果本机是’localhost’
- 参数port:连接的mysql主机的端口,默认是3306
- 参数database:数据库的名称
- 参数user:连接的用户名
- 参数password:连接的密码
- 参数charset:通信采用的编码方式,推荐使用utf8
4.3 对象的方法
- close()关闭连接
- commit()提交
- cursor()返回Cursor对象,用于执行sql语句并获得结果
4.4 Cursor对象
- 用于执行sql语句,使用频度最高的语句为select、insert、update、delete
- 获取Cursor对象:调用Connection对象的cursor()方法
1 | cs1=conn.cursor() |
4.5 对象的方法
- close()关闭
- execute(operation [, parameters ])执行语句,返回受影响的行数,主要用于执行insert、update、delete语句,也可以执行create、alter、drop等语句
- fetchone()执行查询语句时,获取查询结果集的第一个行数据,返回一个元组
- fetchall()执行查询时,获取结果集的所有行,一行构成一个元组,再将这些元组装入一个元组返回
4.6 对象的属性
- rowcount只读属性,表示最近一次execute()执行后受影响的行数
- connection获得当前连接对象
五:python mysql 增删改查
5.1 基础
1 | from pymysql import * |
5.2 查询一行数据
1 | from pymysql import * |
5.3 查询多行数据
1 | from pymysql import * |