1、查询指定列
select sno,sname from student;
AI 代码解读
data:image/s3,"s3://crabby-images/dea2d/dea2dd8a59391514732820e4e35ebd818db8773f" alt="img_79a6b0b9dec569eb7f9a25f3e031cb2f.png"
2、查询全部列
select * from sc;
AI 代码解读
data:image/s3,"s3://crabby-images/9a5c3/9a5c389c5e3ac5a4ee12d063210fc18b3d65a490" alt="img_9d6970a16b2b448612b98b19fe52ea59.png"
3、查询经过计算的值
select sname,2018-sage from student; //目标列是表达式
select sname,'Year of birth:',2018-sage,lower(sdept) from student; //目标表达式可以是字符串常量、函数等
select sname NAME,'Year of birth:' BIRTH, 2018-sage BIRTHDAY,lower(sdept) DEPARTMENT from student; //别名
AI 代码解读
select 子句的目标列表达式不仅可以是属性列,还可以是表达式
data:image/s3,"s3://crabby-images/3566e/3566eb60b37199b4ee472e3e89e85f8c08497f31" alt="img_f13816e97efb1412774dcd5406e586ed.png"
目标列 不仅可以是算术表达式,还可以是字符串常量、函数等。
data:image/s3,"s3://crabby-images/22eb3/22eb375fc64035b39128ecb8f13c26620203a9a6" alt="img_985ff8d7141c35548ef38113daaac1cd.png"
还可以通过指定别名来改变查询结果的列标
data:image/s3,"s3://crabby-images/5d0e2/5d0e24f5cf357802c4b62be3c45e7fb4efc7b8e6" alt="img_0acc36a6578b530b3652be6233d2e9ef.png"
4、消除重复的行
select distinct sno from sc; //distinct 表示去重
select [all] sno from sc; //如果没有指定distinct,则默认是all
AI 代码解读
data:image/s3,"s3://crabby-images/6375f/6375ff34c33b0477a6ce11e34eda4a477e00f57b" alt="img_8d6f93f2e642ac4003f5ff93c16a282d.png"
条件查询
5、比较大小
用于进行比较的运算符一般包括 =,>,<,>=,<=,!=,!>,!<。最后两个分别是不大于,不小于。
//查询计算机科学系全体学生的名单
select sname from student where sdept='CS';
AI 代码解读
data:image/s3,"s3://crabby-images/23250/23250884014b6bf69beb74906c911a47bd917dc7" alt="img_96288de163ee855f3dc8387bcd0cb665.png"
//查询所有年龄在20岁以下的学生姓名及其年龄
select sname,sage from student where sage<20;
AI 代码解读
data:image/s3,"s3://crabby-images/8c891/8c891118dc9895adb63380eb4da4d4eff80562af" alt="img_b53a52c4a390a494f417be2f1ec2652e.png"
//查询考试成绩不及格的学生的学号
select distinct sno from sc where grade<60;
AI 代码解读
data:image/s3,"s3://crabby-images/1264a/1264a3220472295ef957854e131528b026a290a2" alt="img_e12a25daaaa7a6d07379058ea3a5b8ee.png"
6、确定范围
谓词 between…and… 和 not between…and… 可以用来查找属性值在(或不在)指定范围内的无组,其中between后是范围的下限(即低值),and 后是范围的上限(即高值)。
//查询年龄在20~30岁(包括20岁和30岁)之间的学生的姓名、系别和年龄。
select sname,sdept,sage from student where sage between 20 and 30;
AI 代码解读
data:image/s3,"s3://crabby-images/58ca2/58ca2e15e28f8023a72889597aa4d12f79adfca1" alt="img_c140c334936198c7ff877bfc7a45de1b.png"
//查询年龄不在20~30岁之间的学生姓名、系别和年龄。
select sname,sdept,sage from student where sage not between 20 and 30;
AI 代码解读
data:image/s3,"s3://crabby-images/10656/10656749782d2cffd44295b31a1b7b4347342967" alt="img_5629cf08d99018b1f626b05227618007.png"
7、确定集合
谓词 in 和 not in 可以用来查找属性值属于或不属于指定集合的元组
//查询计算机科学系(CS)、数学系(MA)和信息系(IS)学生的姓名和性别。
select sname,ssex from student where sdept in('CS','MA','IS');
AI 代码解读
data:image/s3,"s3://crabby-images/31afb/31afb6a0c47293db7ce423e7f8d0e7eaa4b8f354" alt="img_db3efeb3c7dce293077f0e75512c4142.png"
//查询既不是计算机科学系(CS)、数学系(MA),也不是信息系(IS)学生的姓名和性别。
select sname,ssex from student where sdept not in('CS','MA','IS');
AI 代码解读
data:image/s3,"s3://crabby-images/d214a/d214a4cdc3f9af9802ac2fbd662b4b0d4f61da56" alt="img_adc9f575538b5c4dfe5cabc5d2c24ad3.png"
8、字符匹配
谓词 like 可以用来进行字符串的匹配。%(百分号)代表任意长度(长度可以为0)的字符串。_(下划线)代表任意单个字符。
//查询学号为201215121的学生的详细情况
select * from student where sno like '201215121';
//上式可以等价为
select * from student where sno='201215121';
AI 代码解读
如果 like 后面的匹配串不含通配符,则可以用 = (等于)运算符取代 like 谓词,用 != 或 <>(不等于)运算符取代not like 谓词。
data:image/s3,"s3://crabby-images/be964/be9641e30ba1be0d9ef870c631a6e22a26ab19ec" alt="img_025bfd75daa6f165f7a1ce7ba0db0789.png"
//查询所有姓刘的学生的姓名、学号和性别
select sname,sno,ssex from student where sname like '刘%'; //%代表任意长度
AI 代码解读
data:image/s3,"s3://crabby-images/00a5a/00a5ad22e093224c5538c49c6b62cf984474319d" alt="img_2709767009b0a9c4c984de776817e321.png"
//查询姓“欧阳”且全名为三个汉字的学生的姓名。
select sname,sno from student where sname like '欧阳_';
// _ 一般用于查询明确长度的字符匹配
AI 代码解读
data:image/s3,"s3://crabby-images/02554/025547c94e634c186fb57113096f59f4b5128ae7" alt="img_7cee28e1a6289308dd3369efc49a6384.png"
//查询名字中第二个字为“阳”的学生的姓名和学号
select sname,sno from student where sname like '_阳%';
AI 代码解读
data:image/s3,"s3://crabby-images/12143/12143bb39c86ae9624f36ed2b4873d0dfb0e1ea9" alt="img_0ab25f8475acd1f96497e27b32e07e35.png"
//查询所有不姓刘的学生的姓名、学号和性别
select sname,sno,ssex from student where sname not like '刘%';
AI 代码解读
data:image/s3,"s3://crabby-images/b3d00/b3d0015327505d66a73894b578a6463e8a450469" alt="img_551de8db786d164ea30c4c74ca1449d5.png"
//查询DB_Design课程的课程号和学分
select cno,ccredit from course where cname like 'DB\\_Design';
AI 代码解读
如果条件里面包含一些特殊的字符,那么就要进行转义了,在mysql里面是在特殊字符前面加 \(反斜杠)进行转义。
data:image/s3,"s3://crabby-images/82663/82663ebb8a9d3e124c454e777f246605eda7fcc7" alt="img_57568fb4045b117fc2b4919bed536c66.png"
//查询以“DB_开头,且倒数第三个字符为 i 的课程的详细情况”
select * from course where cname like 'DB\_%i__';
AI 代码解读
data:image/s3,"s3://crabby-images/d5d88/d5d889bb0b4e04f963f183f31800c75365486725" alt="img_ab37e4dbbe92a6c158f7f5c53bb0674f.png"
9、涉及空值的查询
//查询缺少成绩的学生的学号和相应的课程号
select sno,cno from sc where grade is null;
//注意:这里的 “is” 不能用等号(=)来代替
AI 代码解读
data:image/s3,"s3://crabby-images/a974f/a974f01a6a31746e7e17b011412db302eca8e78e" alt="img_f9454bf1aa7a6d6495d147b0d068ccc0.png"
//查询所有有成绩的学生学号和课程号
select sno,cno
-> from sc
-> where grade is not null;
AI 代码解读
data:image/s3,"s3://crabby-images/6b2ba/6b2baf7905643751b3112174c5ffa3cfceebde62" alt="img_7fa7d661c0c4f2ea0f5096d16685e97b.png"
10、多重条件查询
逻辑运算符 and 和 or 可用业连接多个查询条件。and 的优先级高于 or , 但是可以用括号改变优先级。
//查询计算机科学系(CS)、数学系(MA)和信息系(IS)学生的姓名和性别
mysql> select sname, ssex from student
-> where sdept='CS' OR sdept='MA' or sdept='IS';
// in 谓词实际上是多个or运算符的缩写
AI 代码解读
data:image/s3,"s3://crabby-images/fc773/fc7737644207c00dc6bbda8f2427b184d167535c" alt="img_aca43796c5fcb28e2d2cc06a6a3395c1.png"
//查询计算机科学第年龄在20岁以下的学生姓名
mysql> select sname
-> from student
-> where sdept='CS' and sage<20;
AI 代码解读
data:image/s3,"s3://crabby-images/e7e83/e7e832233d1f0b221e3e6657dd1c3f9e57ab0929" alt="img_9ffd8c3a875eb4d3c2c712b418f04a13.png"
10、order by子句
用order by 子句对查询结果一个或多个属性列的升序(asc)或降序(desc)排列,默认值为升序。
//查询选修了3号课程的学生的学号及其成绩,查询结果按分数的降序排列。
mysql> select sno,grade
-> from sc
-> where cno='3'
-> order by grade desc;
AI 代码解读
data:image/s3,"s3://crabby-images/c7aa3/c7aa3582a6ae063eda75e7309888f34bb69c7d6a" alt="img_d18583b8aa806c1649d0bd427de7e382.png"
查询全体学生情况,查询结果按所在系的系号升序排列,同一系的学生按年龄降序排列
mysql> select *
-> from student
-> order by sdept,sage desc;
AI 代码解读
data:image/s3,"s3://crabby-images/bb510/bb51019d86c6bddcfbae1137160b0c5715d83692" alt="img_73edb8933c856ab7dd6bccfce6f821a4.png"
11、聚集函数
//查询学生总人数
mysql> select count(*)
-> from student;
AI 代码解读
data:image/s3,"s3://crabby-images/404a7/404a7ffcb988ec119c006c68f10cfeccc1c7a1eb" alt="img_11dd0ecf962177aa24b30f1b8cb33bed.png"
//查询选修了课程的学生人数
mysql> select count(distinct sno)
-> from sc;
AI 代码解读
data:image/s3,"s3://crabby-images/de20b/de20b2b787afa939256d880c10f83a523c475fa5" alt="img_6990035dd86e88b21d6948afe4675fff.png"
//计算选修1号课程的学生平均成绩
mysql> select avg(grade)
-> from sc
-> where cno='1';
AI 代码解读
data:image/s3,"s3://crabby-images/89987/8998798e810335775aa9b5adc0f7d0eb2af9778b" alt="img_104cc2bdd8230c790a50a48b4e32cba1.png"
//查询选修1号课程的学生最高分
mysql> select max(grade)
-> from sc
-> where cno='1';
AI 代码解读
data:image/s3,"s3://crabby-images/2241c/2241c6c456ee460aa12887fa03d38d239e7c939b" alt="img_b8de5703640d3838afdbf5c8a8380322.png"
//查询学生201215012选修课程的总学分数
mysql> select sum(ccredit)
-> from sc,course
-> where sno='201215012' and sc.cno=course.cno;
AI 代码解读
data:image/s3,"s3://crabby-images/3aaf7/3aaf79c45808fa04ed07ded32d247da6f5696e23" alt="img_d7f312a9dae50ba4c557d55c2b9a09b4.png"
当聚集函数遇到空值时,除 count( ) 外,都跳过空值而只处理非空值。count() 是对元组进行计数,某个元组的一个部分列取空值不影响count的统计结果
注意: where 子句中是不能用聚合函数作为条件表达式的。聚集函数只能用于select 子句和 group by 中的 having 子句。
12、group by 子句
group by 子句将查询结果按某一列或多列的值分组,值相等的为一组。分组后聚集函数将作用于每一个组,即每一组都有一个函数值。
//求各个课程号及相应的选课人数
mysql> select cno,count(sno)
-> from sc
-> group by cno;
AI 代码解读
data:image/s3,"s3://crabby-images/ef030/ef0302a202fc5c55da3106d0d2debc894a3026e9" alt="img_dba5b7b3daf9254026e5e600e5da8442.png"
如果分组后还要求按一定的条件对这些级进行筛选,最终只输出满足指定条件的组,则可以使用having短语指定筛选条件。
//查询选修了三门以上课程的学生学号
mysql> select sno
-> from sc
-> group by sno
-> having count(*)>3;
AI 代码解读
data:image/s3,"s3://crabby-images/17a7e/17a7e8fdd9d82d1485b3c86a079abd3b467e6535" alt="img_b5299ed31ce249a370dc8a85f50c333d.png"
where 子句与 having 短语的区别在于作用对象不同。where 子句作用于基本表或视图,从中选择满足条件的元组。having 短语作用于组,从中选择满足条件的组。
//查询平均成绩大于等于90分的学生学号和平均成绩
mysql> select sno,avg(grade)
-> from sc
-> group by sno
-> having avg(grade)>90;
AI 代码解读
data:image/s3,"s3://crabby-images/86149/861491287c82ac3ba704d2787e00af6f2a3b8c38" alt="img_4f9372a67125d91316567966b618ab47.png"