SQL语句的定义:
概述:
全称叫 Structured Query Language, 结构化查询语言, 主要是实现 用户(程序员) 和 数据库软件(例如: MySQL, Oracle)之间交互用的.
分类:
DDL: 数据定义语言, 主要是操作 数据库, 数据表, 字段, 进行: 增删改查(CURD)
涉及到的关键字: create, drop, alter, show
DML: 数据操作语言, 主要是操作 表数据, 进行: 增删改(CDU) -> 统称为 更新语句.
涉及到的关键字: insert, delete, update
DQL: 数据查询语言, 主要是操作 表数据, 进行: 查询操作®
涉及到的关键字: select, from, where
DCL: 数据控制语言, 主要是 创建用户, 设置权限, 隔离级别等.
通用语法:
- SQL语句可以写一行, 也可以写多行, 最后用 分号 结尾.
- SQL语句不区分大小写, 为了阅读方便, 建议关键字大写, 其它都小写.
- 注释写法:
/* 多行注释的文本 */
# 单行注释
– 单行注释
二, 数据类型的定义
概述:
就是用来限定某列值的范围的, 必须是: 整数, 小数, 字符串, 日期…
常用的数据类型:
- 整型: int
- 浮点型: float, double, decimal
- 日期型: datetime
- 字符串型: varchar(长度)
三, 约束的定义
概述;
在数据类型的基础上, 进一步对该列值做 限定.
(常用的)分类:
单表约束:
- primary key 主键约束, 特点: 非空, 唯一, 一般结合 auto_increment(自动增长, 自增)一起使用.`
- not null 非空约束, 即: 该列值不能为null, 但是可以 重复.
- unique 唯一约束, 即: 该列值必须不重复, 但是可以 为空.
- default 默认约束, 等价于Python的 缺省参数.
多表约束:
- foreign key 外键约束
四, DQL语句(数据查寻语言)
DQL: 数据查询语言, 主要是操作 表数据, 进行: 查询操作®
涉及到的关键字: select, from, where
单表查询
(1) 单表查询 -> 简单查询
格式
# 单表查询, 完整查询格式如下:
select
[distinct] 列名1 as 别名, 列名2 as 别名, ...
from
数据表名
where
组前筛选
group by
分组字段
having
组后筛选
order by
排序字段 [asc| desc]
limit
起始索引, 数据条数;
案例
案例需求
单表查询 -> 简单查询
实现思路
- 创建商品表.
- 添加表数据.
- 查看表数据.
- 需求1: 查询所有的商品信息.
- 需求2: 查看商品名 和 商品价格.
- 扩展: 起别名: 列名, 表名都可以起别名.
- 格式: 列名 as 别名 或者 表名 as 别名, 其中 as 可以省略不写.
- 需求3: 查看结果是表达式, 将所有的商品价格+ 10, 进行展示.
# 1. 创建商品表.
create table product
(
pid int primary key auto_increment, # 商品id, 主键
pname varchar(20), # 商品名
price double, # 商品单价
category varchar(32) # 商品的分类id
);
# 2. 添加数据表.
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'联想',5000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'海尔',3000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'雷神',5000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'杰克琼斯',800,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'真维斯',200, null);
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'花花公子',440,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'劲霸',2000,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'香奈儿',800,'c003');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'相宜本草',200, null);
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'面霸',5,'c003');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'好想你枣',56,'c004');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'香飘飘奶茶',1,'c005');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'海澜之家',1,'c002');
# 3. 查看表数据.
# 4. 需求1: 查询所有的商品信息
select * from product;
select pid, pname, pricem category_id from product; # 效果同上.
# 5. 需求2: 查看商品名 和 商品价格.
select pname, price from product;
# 6. 扩展: 起别名: 列名, 表名都可以起别名.
# 7. 格式: 列名 as 别名 或者 表名 as 别名, 其中 as 可以省略不写.
select pname as 商品名, price 商品价格 from product as p;
# 8. 需求3: 查看结果是表达式, 将所有的商品价格+10, 进行展示.
select pname, price + 10 from product;
select pname, price + 10 as price from product;
(2)单表查询 -> 条件查询 -> 比较运算符
格式:
select 列名1, 列名2... from 数据表名 where 条件;
案例
案例需求
单表查询 -> 条件查询 -> 比较运算符
实现思路
- 创建商品表.
- 添加表数据.
- 查看表数据.
- 需求1: 查询所有的商品信息.
- 需求2: 查看商品名 和 商品价格.
- 格式 : select 列名1, 列名2… from 数据列表 where 条件;
- 场景1: 比较运算符, >, >=, <, <=, =, !=, <>
- 需求1: 查询商品名称为"花花公子"的商品所有信息:
- 需求2: 查询价格为800商品.
- 需求3: 查询价格不是800的所有商品.
- 需求4: 查询商品价格大于60元的所有商品信息.
- 需求5: 查询商品价格小于等于800元的所有商品信息.
# 1. 创建商品表.
create table product
(
pid int primary key auto_increment, # 商品id, 主键
pname varchar(20), # 商品名
price double, # 商品单价
category varchar(32) # 商品的分类id
);
# 2. 添加数据表.
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'联想',5000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'海尔',3000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'雷神',5000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'杰克琼斯',800,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'真维斯',200, null);
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'花花公子',440,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'劲霸',2000,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'香奈儿',800,'c003');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'相宜本草',200, null);
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'面霸',5,'c003');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'好想你枣',56,'c004');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'香飘飘奶茶',1,'c005');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'海澜之家',1,'c002');
# 3. 查看表数据.
# 4. 需求1: 查询所有的商品信息
select * from product;
select pid, pname, pricem category_id from product; # 效果同上.
# 5. 需求2: 查看商品名 和 商品价格.
select pname, price from product;
# 6. 格式: select 列名1, 列明2... from 数据表名 where 条件;
# 7. 场景1: 比较运算符, >, >=, <, <=, =, !=, <>.
# 8. 需求1: 查询商品名称为"花花公子"的商品所有信息.
select * from product where pname = '花花公子';
# 9. 需求2: 查询价格为800商品.
select * from product where price = 800;
# 10. 需求3: 查询价格不是800的所有商品.
select * from product where price != 800;
select * from product where price <> 800; # 效果同上
# 11. 需求4: 查询商品价格大于60元的所有商品信息.
select * from product where price > 60;
# 12. 需求5: 查询商品价格小于等于800元的所有商品信息.
select * from product where price <= 800;
(3)单表查询 -> 条件查询 -> 逻辑运算符和范围查询
案例需求
- 创建商品表.
- 添加表数据.
- 查看表数据.
- 需求1: 查询所有的商品信息.
- 需求2: 查看商品名 和 商品价格.
- 格式 : select 列名1, 列名2… from 数据列表 where 条件;
- 场景2: 范围查询. between 值1 and 值2 -> 适用于连续的区间, in (值1, 值2…) -> 适用于 固定值的判断.
- 场景3: 逻辑运算符. and, or, not
- 需求6: 查询商品价格在200到800之间所有商品.
- 需求7: 查询商品价格是200或800的所有商品.
- 需求8: 查询价格不是800的所有商品.
# 1. 创建商品表.
create table product
(
pid int primary key auto_increment, # 商品id, 主键
pname varchar(20), # 商品名
price double, # 商品单价
category varchar(32) # 商品的分类id
);
# 2. 添加数据表.
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'联想',5000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'海尔',3000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'雷神',5000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'杰克琼斯',800,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'真维斯',200, null);
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'花花公子',440,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'劲霸',2000,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'香奈儿',800,'c003');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'相宜本草',200, null);
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'面霸',5,'c003');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'好想你枣',56,'c004');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'香飘飘奶茶',1,'c005');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'海澜之家',1,'c002');
# 3. 查看表数据.
# 4. 需求1: 查询所有的商品信息
select * from product;
select pid, pname, pricem category_id from product; # 效果同上.
# 5. 需求2: 查看商品名 和 商品价格.
select pname, price from product;
# 6. 场景2: 范围查询. between 值1 and 值2 -> 适用于连续的区间, in (值1, 值2...) -> 适用于 固定值的判断.
# 7. 场景3: 逻辑运算符. and, or, not
# 8. 需求6: 查询商品价格在200到800之间所有商品.
select * from product where price between 200 and 800; # 包左包右.
select * from product where price price >= 200 and price <= 800;
# 9. 需求7: 查询商品价格是200或800的所有商品.
select * from product where price in (200, 800);
select * from product where price = 200 or price = 800;
# 10. 需求8: 查询价格不是800的所有商品.
select * from product where price != 800;
select * from product where not price = 800;
select * from product where price not in (800);
(4)单表查询 -> 条件判断 -> 模糊查询和非空判断
案例需求
单表查询 -> 条件判断 -> 模糊查询和非空判断
实现思路
- 创建商品表.
- 添加表数据.
- 查看表数据.
- 需求1: 查询所有的商品信息.
- 需求2: 查看商品名 和 商品价格.
- 场景4: 模糊查询. 字段名 like ‘_内容%’ _ 代表任意的1个字符 ; %代表任意的多个字符, 至少0个 , 至多无所谓.
- 需求9: 查询以’香’开头的所有商品.
- 需求10: 查询第二个字为’想’的所有商品.
- 场景5: 非空查询. is null, is not null, 不能用 = 来判断空.
- 需求11: 查询没有分类的商品.
- 需求12: 查询有分类的商品.
# 1. 创建商品表.
create table product
(
pid int primary key auto_increment, # 商品id, 主键
pname varchar(20), # 商品名
price double, # 商品单价
category varchar(32) # 商品的分类id
);
# 2. 添加数据表.
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'联想',5000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'海尔',3000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'雷神',5000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'杰克琼斯',800,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'真维斯',200, null);
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'花花公子',440,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'劲霸',2000,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'香奈儿',800,'c003');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'相宜本草',200, null);
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'面霸',5,'c003');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'好想你枣',56,'c004');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'香飘飘奶茶',1,'c005');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'海澜之家',1,'c002');
# 3. 查看表数据.
# 4. 需求1: 查询所有的商品信息
select * from product;
select pid, pname, pricem category_id from product; # 效果同上.
# 5. 需求2: 查看商品名 和 商品价格.
select pname, price from product;
# 6. 场景4: 模糊查询. 字段名 like '_内容%' _ 代表任意的1个字符; %代表任意的多个字符, 至少0个, 至多无所谓.
# 7. 需求9:查询以'香'开头的所有商品.
select * from product where pname like '香%';
# 8. 需求10: 查询第二个字为'想'的所有商品.
select * from product where pname like '想%';
select * from product where pname like '想'; # 只能查出 *想 两个字的, 不符合题设.
# 9. 场景5: 非空查询. is null, is not nunll, 不能用=来判断空.
# 10. 需求11: 查询没有分类的商品.
select * from product where category_id = null; # 不报错, 但是没有结果.
select * from product where category_id is null; # 正确的, 判空操作.
# 11. 需求12: 查询有分类的商品.
select * from product where category_id is not null; # 正确的, 非空判断操作.
(5)单表查询 -> 排序查询
格式:
select * from 表名 order by 排序的字段1 [asc | desc], 排序的字段2 [asc | desc], ...;
解释: 1. ascending: 升序, descending: 降序.
解释: 2. 默认是升序, 所以asc可以省略不写.
案例
- 创建商品表.
- 添加表数据.
- 查看表数据.
- 需求1: 查询所有的商品信息.
- 需求2: 查看商品名 和 商品价格.
- 需求1: 根据价格降序排列.
- 需求2: 根据价格降序排列, 价格一样的情况下, 根据分类降序排列.
# 1. 创建商品表.
create table product
(
pid int primary key auto_increment, # 商品id, 主键
pname varchar(20), # 商品名
price double, # 商品单价
category varchar(32) # 商品的分类id
);
# 2. 添加数据表.
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'联想',5000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'海尔',3000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'雷神',5000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'杰克琼斯',800,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'真维斯',200, null);
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'花花公子',440,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'劲霸',2000,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'香奈儿',800,'c003');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'相宜本草',200, null);
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'面霸',5,'c003');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'好想你枣',56,'c004');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'香飘飘奶茶',1,'c005');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'海澜之家',1,'c002');
# 3. 查看表数据.
# 4. 需求1: 查询所有的商品信息
select * from product;
select pid, pname, pricem category_id from product; # 效果同上.
# 5. 需求2: 查看商品名 和 商品价格.
select pname, price from product;
# 6. 需求1: 根据价格降序排列.
select * from product order by price; # 默认是: 升序.
select * from product order by price asc; # 效果同上.
select * from product order by price desc; # 价格降序排列.
# 7. 需求2: 根据价格降序排列, 价格一样的情况下, 根据分类降序排列.
select * from product order by price desc, category_id desc;
(6) 单表查询 -> 聚合查询
定义
概述:
聚合查询是对表中的某列表数据做操作.
常用的聚合函数:
- count() 统计某列值的个数, 只统计非空值. 一般用于统计 表中数据的总条数.
- sum() 求和
- max() 求最大值
- min() 求最小值
- avg() 求平均值
扩展: count(*), count(1), count(列)的区别是什么
区别1: 是否统计空值
- count(列): 只统计该列的非空值.
- count(1), count(*): 统计所有数据, 包括空值.
区别2: 效率问题
count(主键列) > count(1) > count(*) > count(普通列)
案例
案例需求
单表查询 -> 聚合查询
实现思路
- 创建商品表.
- 添加表数据.
- 查看表数据.
- 需求1: 查询所有的商品信息.
- 需求2: 查看商品名 和 商品价格.
- 需求1: 查询商品的总条数.
- 需求2: 查询价格大于200商品的总条数.
- 需求3: 查询分类为’c001’的所有商品价格的总和.
- 需求4: 查询分类为’c002’的所有商品的平均价格.
- 需求5:查询商品的`最大价格和最小价格 扩展: ctrl + alt + 字母L 代码格式化.
# 1. 创建商品表.
create table product
(
pid int primary key auto_increment, # 商品id, 主键
pname varchar(20), # 商品名
price double, # 商品单价
category varchar(32) # 商品的分类id
);
# 2. 添加数据表.
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'联想',5000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'海尔',3000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'雷神',5000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'杰克琼斯',800,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'真维斯',200, null);
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'花花公子',440,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'劲霸',2000,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'香奈儿',800,'c003');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'相宜本草',200, null);
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'面霸',5,'c003');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'好想你枣',56,'c004');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'香飘飘奶茶',1,'c005');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'海澜之家',1,'c002');
# 3. 查看表数据.
# 4. 需求1: 查询所有的商品信息
select * from product;
select pid, pname, pricem category_id from product; # 效果同上.
# 5. 需求2: 查看商品名 和 商品价格.
select pname, price from product;
# 6. 需求1: 查询商品的总条数.
select count(pid) as total_cnt from product;
select count(category_id) as total_cnt from product;
select count(*) as total_cnt from product;
select count(1) as total_cnt from product;
# 7. 需求2: 查询价格大于200商品的总条数.
select count(pid) as total_cnt from product where price > 200;
# 8. 需求3: 查询分类为'c001'的所有商品价格的总和.
select sum(price) as total_price from product where category_id = 'c001'
# 9. 需求4: 查询分类为'c002'的所有商品的平均价格.
select avg(price) as avg_price from product where category_id = 'c002';
# 10. 需求5: 查询商品的最大价格和最小价格 扩展: ctrl + alt + 字母L 代码格式化.
select
max(price) as max_price,
min(price) as min_price
from
product;
(6) 单表查询 -> 分组查询
图解
分组查询定义
概述:
简单理解为, 根据分组字段, 把表数据 化整为零, 然后基于每一个分组后的每个部分, 进行对应的聚合运算.
格式:
select 列1, 列2, ... from 数据表名 where 组前筛选 group by 分组字段 having 组后筛选;
细节
- 分组查询 一般要结合 聚合函数一起使用, 且根据谁分组, 就根据谁查询.
- 组前筛选用where, 组后筛选用having.
- where 和 having的区别是什么?
- where: 组前筛选, 后边不能跟聚合函数.
- having: 组后筛选, 后边可以跟聚合函数.
- 分组查询的查询列 只能出现 分组字段, 聚合函数.
- 如果只分组, 没有写聚合, 可以理解为是:基于分组字段, 进行去重查询.
案例
案例需求
- 创建商品表.
- 添加表数据.
- 查看表数据.
- 需求1: 查询所有的商品信息.
- 需求2: 查看商品名 和 商品价格.
- 需求1: 统计各个分类商品的个数.
- 需求2: 统计各个分类商品的个数, 且只显示个数大于1的信息.
- 需求3: 演示 如果只分组, 没有写聚合, 可以理解为是: 基于分组字段, 进行去重查询.
- 还可以通过 distinct 关键字来实现去重.
- 此时是: 按照category_id 和 price作为整体, 然后去重.
# 1. 创建数据表.
create table product
(
pid int primary key auto_increment, # 商品id, 主键
pname varchar(20), # 商品名
price double, # 商品单价
category varchar(32) # 商品的分类id
);
# 2. 添加数据表.
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'联想',5000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'海尔',3000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'雷神',5000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'杰克琼斯',800,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'真维斯',200, null);
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'花花公子',440,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'劲霸',2000,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'香奈儿',800,'c003');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'相宜本草',200, null);
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'面霸',5,'c003');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'好想你枣',56,'c004');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'香飘飘奶茶',1,'c005');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'海澜之家',1,'c002');
# 3. 查看数据表.
# 4. 需求1: 查询所有的商品信息.
select * from product;
select pid, pname, pricem, category_id from product; # 效果同上.
# 5. 需求2: 查看商品名 和 商品价格.
select panme, price from product;
# 6. 需求1: 统计各个各个分类商品的个数.
select category_id, count(*) as total_cnt from product group by category_id;
# 7. 需求2: 统计各个分类商品的个数, 且只显示个数大于1的信息.
select
category_id,
count(*) as total_cnt
from
product
group by
category_id # 根据商品类别分组.
having
total_cnt > 1; # 组后筛选
# 8. 需求3: 演示 如果只分组, 没有写聚合, 可以理解为是: 基于分组字段, 进行去重查询.
select category_id from product group by category_id;
select category_id from product group by category_id;
# 9. 还可以通过 distinct 关键字来实现去重.
select distinct category_id from product;
# 10. 此时是: 按照category_id 和 price 作为整体, 然后去重.
select distinct category_id, price from product;
select category_id, price from product group by category_id, price; # 效果同上.
(7)单表查询 -> 分页查询
分页查询的定义
概述:
分页查询 = 每次从数据表中查询出固定条数的数据, 一方面可以降低服务器的压力, 另一方面可以降低浏览器的压力, 且可以提高用户的体验.
格式:
limit 起始索引, 数据条数;
细节:
- 表中每条数据都有自己的索引, 且索引是从0开始的.
- 如果是从索引0开始获取数据的, 则索引0可以省略不写.
- 要学好分页, 掌握如下的几个参数计算规则即可:
- 数据总条数: count() 函数
- 每页的数据条数: 产品经理, 项目经理, 你…
- 每页的起始索引: (当前的页数 - 1) * 每页的数据条数
- 总页数: (数据总条数 + 每页的数据条数 - 1) // 每页的数据条数
-
(13 + 5 - 1) // 5 = 17 // 5 = 3 页 (14 + 5 - 1) // 5 = 18 // 5 = 3 页 (15 + 5 - 1) // 5 = 19 // 5 = 3 页 (16 + 5 - 1) // 5 = 20 // 5 = 4 页
案例
案例需求
单表查询 -> 分页查询
实现思路
- 创建商品表.
- 添加表数据.
- 查看表数据.
- 需求1: 查询所有的商品信息.
- 需求2: 查看商品名 和 商品价格.
- 需求1: 5条/页.
- 需求2: 3条/页.
# 1. 创建商品表.
create table product
(
pid int primary key auto_increment, # 商品id, 主键
pname varchar(20), # 商品名
price double, # 商品单价
category varchar(32) # 商品的分类id
)
# 2. 添加数据表.
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'联想',5000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'海尔',3000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'雷神',5000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'杰克琼斯',800,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'真维斯',200, null);
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'花花公子',440,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'劲霸',2000,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'香奈儿',800,'c003');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'相宜本草',200, null);
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'面霸',5,'c003');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'好想你枣',56,'c004');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'香飘飘奶茶',1,'c005');
INSERT INTO product(pid,pname,price,category_id) VALUES(null,'海澜之家',1,'c002');
# 3. 查看数据表.
# 4. 需求1: 查询所有的商品信息.
select * from product;
select pid, pname, pricem, category_id from product; # 效果同上.
# 5. 需求2: 查看商品名 和 商品价格.
select panme, price from product;
# 6. 需求1: 统计各个各个分类商品的个数.
select category_id, count(*) as total_cnt from product group by category_id;
# 7. 需求1: 5条/页.
select * from product limit 5; # 第1页, 从索引0开始, 获取5条.
select * from product limit 0, 5; # 第1页, 从索引0开始, 获取5条, 效果同上.
select * from product limit 5, 5; # 第2页, 从索引5开始, 获取5条.
# 8. 需求2: 3条/页.
select * from product limit 0, 3; # 第1页, 从索引0开始, 获取3条.
select * from product limit 3, 3; # 第2页, 从索引3开始, 获取3条.
select * from product limit 6, 3; # 第3页, 从索引6开始, 获取3条.
select * from product limit 9, 3; # 第4页, 从索引9开始, 获取3条.
select * from product limit 12, 3; # 第5页, 从索引12开始, 获取3条.
五, 总结
select
[distinct] 列1 as 别名, 列2 as 别名
from
数据列表
where
组前筛选
group by
分组字段
having
组后筛选
order by
排序字段 [asc | desc]
limit
起始索引, 数据条数;