data:image/s3,"s3://crabby-images/c2623/c262349a76515a164a7a5e912a0ce4f9c81c595b" alt=""
表格字段设置如图
data:image/s3,"s3://crabby-images/5b83a/5b83a31d5e07eaf245de8e93279397008da73b33" alt=""
语句:
1.输出
1.输出name和age列
sql
SELECT name,age from student
1.2.全部输出
sql
select * from student
2.where子语句
1.运算符:
=等于
>大于
>=大于等于
<小于
<=小于等于
!= <>不等于
sql
select * from student where age!=24
data:image/s3,"s3://crabby-images/78ba2/78ba2d8c60d11e18859cd94e9f71b7fc59d4680f" alt=""
sql
select * from student where age<24
data:image/s3,"s3://crabby-images/abd17/abd172343293aee28d994d6e9f444d74ee922aa1" alt=""
2.逻辑运算符:
and 并且
or 或者
not 取非 主要用在is 或in
sql
select * from student where age>=24 and sex="女" and name="admin"
data:image/s3,"s3://crabby-images/c20b4/c20b4f42926970d24793b90d05139732f2ba965b" alt=""
sql
select * from student where age>=24 or sex="男"
data:image/s3,"s3://crabby-images/c1704/c1704f7ab3f57ae243374dc7a08641fe630774b6" alt=""
sql
select * from student where age>=20 and age<=24
data:image/s3,"s3://crabby-images/ab2e3/ab2e344ca12130626d5072d0ca028749a581e1e7" alt=""
3.范围
between ..and ..范围查询,在两个值之间
in 范围查询 包含
sql
select * from student where id between 3 and 5
data:image/s3,"s3://crabby-images/58013/58013ed151c55f3f5b6d0c4d695c2e593cfc9abb" alt=""
sql
select * from student where id not in(1,4,5)
data:image/s3,"s3://crabby-images/00101/001013bbba017c3db96f5d6177e772a7c46607ba" alt=""
4.空
is null 为null
sql
select * from student where age is not null
data:image/s3,"s3://crabby-images/bc057/bc057adc07f600bc46eae79af20869f6bb2c50ff" alt=""
模糊查询 like 为模糊查询 需要配合占位符一起使用 _代表一位字符 %代表任意位字符
3.分页查询
1.语句
limit a,b ----a表示起始的索引值 b表示查询的个数
limit b offset a
sql
select * from student limit 0,5
data:image/s3,"s3://crabby-images/95157/95157948d5ec291eebb680ef8f50561bae2ab695" alt=""
eg.
一页3个 pagesize
$1.第一页 page
sql
select * from student limit 0,3
data:image/s3,"s3://crabby-images/ed016/ed016dad68ccfa04b9ff8b1b13359ee15cffb113" alt=""
$2. 第二页
sql
select * from student limit 3,3
data:image/s3,"s3://crabby-images/364b0/364b064bbd82729b033e13eadcacfc6389ac3f67" alt=""
$3. 第三页
sql
select * from student limit 6,3
data:image/s3,"s3://crabby-images/f05cd/f05cd4ce7aa2c53e03bee632d8320a65a854f737" alt=""
$4.第四页
sql
select * from student limit 9,3
data:image/s3,"s3://crabby-images/cbe8c/cbe8cf962666153b1cbb9b1125f90a51a9e09f75" alt=""
2.总结 :
select * from student limit (page-1)*pagesize,pagesize
3.位置:
limit 子语句放在最后位置
sql
select * from student where sex="男" limit 0,3
data:image/s3,"s3://crabby-images/29c00/29c001293a0b7ef949c8446d06b1eeb3c325a6e1" alt=""
4.排序子语句
1.语句
order by 列名 desc降序排列 || asc升序
sql
select * from student ORDER BY age desc
data:image/s3,"s3://crabby-images/eb483/eb4838b00dbe1619f613407e0116b33316a02c78" alt=""
2.位置:
排序子语句的相对位置
在where子语句之后 在limit子语句之前
sql
select * from student where sex="女" order by class_num desc limit 0,3
data:image/s3,"s3://crabby-images/3eb54/3eb54c2db4caf1f8d0bc390062a59ece2d337174" alt=""
5.分组函数和聚合函数
1.聚合函数
-- sum()求和
-- min()取最小值
-- max() 取最大值
-- avg()取平均值
-- count()取得的记录数量 count(*)表示取得当前查询表的所有记录数
count(字段名称)不会统计为null的记录
sql
select count(age) from student
data:image/s3,"s3://crabby-images/37e5b/37e5bd4a13c479bbb78a855ba31e21231a93b30b" alt=""
sql
select count(*) from student
data:image/s3,"s3://crabby-images/dccda/dccdafca2a3e9efd007174cf4570dca00c03e45c" alt=""
2.分组函数
GROUP BY 字段名称 分完组之后做查找用having
sql
select max(age),class_num from student GROUP BY class_num
data:image/s3,"s3://crabby-images/e806f/e806fd2999a15a9e91e843c3673d71c8ffc76b21" alt=""
sql
select max(age),class_num from student GROUP BY class_num having class_num=2
data:image/s3,"s3://crabby-images/f77ba/f77bae700843335d1e8bf70b7242da060a3eadf7" alt=""
2.多表查询
1.关系
data:image/s3,"s3://crabby-images/7e93a/7e93ae16598159373f77ad51783eec501c00ec81" alt=""
1.1 一对一
data:image/s3,"s3://crabby-images/75014/75014812065c2f80786427487d12765ab802c7a4" alt=""
$ 1.合并成一张表 效果最好
data:image/s3,"s3://crabby-images/a39e4/a39e42d6d429de03526c13096d0a8a827094a993" alt=""
data:image/s3,"s3://crabby-images/0b4db/0b4dbf748fc272c1292aa0343c99e1404968cb75" alt=""
$ 2. 在其中一张表加入外键
data:image/s3,"s3://crabby-images/fa166/fa166fa6e9579116449e83c4f9f00526dd070923" alt=""
&&or
data:image/s3,"s3://crabby-images/feb06/feb0617a87aae4523569d149024a29b3db85fba6" alt=""
$3. 单独创建一张表存关系
data:image/s3,"s3://crabby-images/c17cb/c17cb9dbee6fbbc458f8085596a445ecd358e22d" alt=""
1.2 一对多
学生对班级
data:image/s3,"s3://crabby-images/e8dfd/e8dfde868f85720f4baf2fff26d2193c029a1475" alt=""
$1. 合成一张表
data:image/s3,"s3://crabby-images/53c35/53c35053774acf97d3399daa49e527ae8e832555" alt=""
缺点:有多少学生这些信息得存多少遍 数据冗余
data:image/s3,"s3://crabby-images/abd17/abd17cf8588b5f4d06fe3c968734b929e2aa86e2" alt=""
$2. 在多方加入外键 效果最好
修改班级等方便, &&查看班级多少人,只需看cid有多少个
data:image/s3,"s3://crabby-images/6d0c2/6d0c27347009d739096ac074ba2f8543a7b73e44" alt=""
data:image/s3,"s3://crabby-images/39e17/39e17e3d8e4a0d7056ed7b527167c99fb91b7868" alt=""
②在1方加入外键 数据冗余
data:image/s3,"s3://crabby-images/ad293/ad293d2ecc0d6cd7a8423e47244b9c9896d4eab1" alt=""
$3. 单独创建一张表存关系
data:image/s3,"s3://crabby-images/4906e/4906e448a3d1d862735bc000155d213701735170" alt=""
1.3 多对多
学生对课程
data:image/s3,"s3://crabby-images/678d0/678d094d0311507eebae37e41a795ed1eec99c7a" alt=""
课程对学生
$1. 合并成一张表----->重复
data:image/s3,"s3://crabby-images/40d82/40d821eeb435ccc879e1448e025299072533af12" alt=""
$2. 加外键
在谁方谁冗余
①学生方
data:image/s3,"s3://crabby-images/8a78d/8a78d8237425752c409b713dbdfcaadc84a74b75" alt=""
②课程方
data:image/s3,"s3://crabby-images/dbb1d/dbb1d62d4e28ce3c24bde634502b17acbb4c803d" alt=""
$3. 单独创建一张表存关系
data:image/s3,"s3://crabby-images/a537c/a537c99ef958558ff3d53111627e10c19064587c" alt=""
data:image/s3,"s3://crabby-images/72088/72088438cd71e001cb31b243d877e301500138d1" alt=""
data:image/s3,"s3://crabby-images/7000c/7000c6ea815ad3d9366b05a159f18d9fc2782c4e" alt=""
1.4 结论:
data:image/s3,"s3://crabby-images/b6f06/b6f0614478ba6b16ac97e531822d8d32dd04ca06" alt=""
2.查询
$1. 建立班级表和学生表
$2. 添加外键
data:image/s3,"s3://crabby-images/056a5/056a52dbb88883061a5f47a4ce3bfd1b3c0383d0" alt=""
$3. 填入数据
$4. 查询
sql
select * from 班级表,学生表 where 学生表.cid=班级表.id
data:image/s3,"s3://crabby-images/ad030/ad03012f640fab3d79e42f28012a631c5b83f74e" alt=""
-- 连表查询 join on
-- 内连接
-- 外连接 左外连接和右外连接
把where的地方换成on
sql
select * from 班级表 join 学生表 on 学生表.cid=班级表.id
data:image/s3,"s3://crabby-images/429e2/429e2f40131405efc20f0ca1515f6b5d13710e2e" alt=""
#左连接 (公共的部分加上左边空的<独有的>)
sql
select * from 班级表 left join 学生表 on 学生表.cid=班级表.id
data:image/s3,"s3://crabby-images/47e15/47e15d27af42256975a6e4cf45bc64fc197a496b" alt=""
#右连接(公共的部分加上右边空的<独有的>)
sql
select * from 班级表 right join 学生表 on 学生表.cid=班级表.id
data:image/s3,"s3://crabby-images/835ea/835ea2ab890f5378365ac86c0db3c32acbd48053" alt=""