CREATE TABLE student (
id INT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
sn INT UNSIGNED UNIQUE KEY,
name VARCHAR(20) NOT NULL,
qq VARCHAR(32) UNIQUE KEY
);
执行结果:
mysql>desc student;
+-------+------------------+------+-----+---------+----------------+| Field | Type |Null| Key |Default| Extra |+-------+------------------+------+-----+---------+----------------+| id |int(10) unsigned |NO| PRI |NULL| auto_increment |
sn () unsigned YES UNI
name ()
qq () YES UNI
( sec)
CREATE TABLE exam_result (
id INT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
name VARCHAR(20) NOT NULL COMMENT '同学姓名',
chinese FLOATDEFAULT0.0 COMMENT '语文成绩',
math FLOATDEFAULT0.0 COMMENT '数学成绩',
english FLOATDEFAULT0.0 COMMENT '英语成绩'
);
INSERT INTO exam_result (name, chinese, math, english) VALUES
('唐三藏', 67, 98, 56),
('孙悟空', 87, 78, 77),
('猪悟能', 88, 98, 90),
('曹孟德', 82, 84, 67),
('刘玄德', 55, 85, 45),
('孙权', 70, 73, 78),
('宋公明', 75, 65, 30);
2.1 select 列
【全列查询】
通常情况下不建议使用 * 进行全列查询。
查询的列越多,意味着需要传输的数据量越大;
可能会影响到索引的使用。
【指定列查询】
指定列的顺序不需要按定义表的顺序来。
【查询字段为表达式】
可以给指定列进行重命名,格式:原名 as 新名,as 可以省略。
【distinct 结果去重】
使用 DISTINCT 关键字去除重复行。
2.2 where 条件
比较运算符
NULL 无法参与 = 的比较,但是可以参与 <=> 的比较。我们只需要记住,= 对于 NULL 是不安全的,后面判断 NULL 使用 IS NULL,IS NOT NULL 即可。
逻辑运算符
AND, OR, NOT
案例:
【英语不及格的同学及英语成绩 (< 60)】
SELECT name, english FROM exam_result WHERE english <60;
【语文成绩在 [80, 90] 分的同学及语文成绩】
SELECT name, chinese FROM exam_result WHERE chinese BETWEEN80AND90;
【数学成绩是 58 或者 59 或者 98 或者 99 分的同学及数学成绩】
SELECT name, math FROM exam_result WHERE math IN (58, 59, 98, 99);
【姓孙的同学 及 孙某同学】
% 匹配任意多个(包括 0 个)任意字符
_ 匹配严格的一个任意字符
SELECT name FROM exam_result WHERE name LIKE'孙%'; -- 姓孙SELECT name FROM exam_result WHERE name LIKE'孙_'; -- 孙某
【语文成绩好于英语成绩的同学】
SELECT name FROM exam_result WHERE chinese > english;
【总分在 200 分以下的同学】
WHERE 条件中使用表达式
别名不能用在 WHERE 条件中
SELECT name, (chinese + math + english) AS total FROM exam_result WHERE (chinese + math + english) <200;
【语文成绩 > 80 并且不姓孙的同学】
SELECT name FROM exam_result WHERE chinese >80AND name NOTLIKE'孙%';
【孙某同学,否则要求总成绩 > 200 并且 语文成绩 < 数学成绩 并且 英语成绩 > 80】
SELECT name, chinese, math, english, chinese + math + english AS total
FROM exam_result
WHERE name LIKE'孙_'OR (chinese + math + english >200AND chinese < math AND english >80);