目录
1.新增
1.1单行数据 +全列插入
1.2多行数据 + 全列插入
1.3指定插入
2.查询
2.1全列查询
2.2指定列查询
2.3查询字段为表达式
2.4别名
2.5 去重
2.6排序
编辑 2.7条件查询
3.修改(Update)
4.删除(Delete)
insert into 表名 values(列,列……);
注意:
这里给出的列的数目和类型,都要和表结构相匹配。
insert into 表名 values(列,列……),(列,列……)……;
例1.1:
-- 创建考试成绩表
DROP TABLE IF EXISTS exam_result;
CREATE TABLE exam_result (
id INT,
name VARCHAR(20),
chinese DECIMAL(3,1),
math DECIMAL(3,1),
english DECIMAL(3,1)
);
-- 插入测试数据
INSERT INTO exam_result (id,name, chinese, math, english) VALUES
(1,'唐三藏', 67, 98, 56),
(2,'孙悟空', 87.5, 78, 77),
(3,'猪悟能', 88, 98.5, 90),
(4,'曹孟德', 82, 84, 67),
(5,'刘玄德', 55.5, 85, 45),
(6,'孙权', 70, 73, 78.5),
(7,'宋公明', 75, 65, 30);
insert into 表名(列……)values(列,列……),(列,列……)……;
思考:
比如,现在我想要插入10行数据,我有两种操作。
(1)写一条SQL语句,一次性插入10条。
(2)写十条SQL语句,插10次。
结论:第一种方式的执行效率要比 第二种方式的执行效率高。
select * from 表名
注意:通常情况下不建议使用 * 进行全列查询
以例题1.1为例。
一旦数据过大,此时这个操作就会产生大量的硬盘IO和网络IO,就可能会把硬盘或网卡的宽带给吃满(吃满可以理解成堵车)。
一旦宽带吃满,此时服务器就无法正常响应,其他客户的请求。
思考:
那我可以强制停止吗?
强制停止本质上也是通过客户端给服务器发出一个“停止”请求,但应此时宽带吃满了,“停止”请求也被堵在半路上。
只查询你指定列查询
select 列名…… from 表名
指定列的顺序不需要按定义表的顺序来
但是,这种查询也不是万无一失的。
虽然你查询的列数可能很少,但你查询的列的行数很多,此时也可能 宽带吃满。
select 表达式 from 表名
细节:
以例题1.1为例。
select 表达式 (as) 别名 from 表名
例如:
-- 结果集中,表头的列名 = 别名SELECT id, name, chinese + math + english 总分 FROM exam_result;
select distinct 列名,……from 表名
例如:
以例题1.1为例。
select 列名,……from 表名 order by 列名,……;
注意:
1. 没有 ORDER BY 子句的查询,返回的顺序是未定义的,永远不要依赖这个顺序 。
2. NULL 数据排序,视为比任何值都小,升序出现在最上面,降序出现在最下面。3.无特殊说明默认为 升序。降序:~~order by 列名 desc;此时的desc=>descand 降序的意思。4.字符比大小是按“字典序”排序的。5. 可以对多个字段进行排序,排序优先级随书写顺序。意思为,order by指定多个列时是带优先级的,前面的列优先级高,后面的列优先级低。优先级高的列的值相同,才会比较优先级低的列。
对于注意3,5的举例:
以例题1.1为例。
select 列名,……from 表名 where 条件;
比较运算符:
逻辑运算符:
注意事项:
WHERE条件可以使用表达式,但不能使用别名。
AND的优先级高于OR,在同时使用时,需要使用小括号()包裹优先执行
利用举例补充注意事项
以下均与例题1.1为例。
(1)一般使用:查询英语不及格的同学及英语成绩 ( < 60 )
(2)查询语文成绩好于英语成绩的同学
进行比较的时候,不仅仅是一个列和常量的比较,也可以是两个列或多个列的比较。
(3)查询总分在 200 分以下的同学
WHERE条件可以使用表达式,但不能使用别名
正确:
(4)AND与OR
1.一般使用:
-- 查询语文成绩大于80分,且英语成绩大于80分的同学
SELECT * FROM exam_result WHERE chinese > 80 and english > 80;
-- 查询语文成绩大于80分,或英语成绩大于80分的同学
SELECT * FROM exam_result WHERE chinese > 80 or english > 80;
2.一个where中,有ang有or,会先执行and再执行or,需要使用小括号()包裹优先执行
-- 观察AND 和 OR 的优先级:
SELECT * FROM exam_result WHERE chinese > 80 or math>70 and english > 70;
SELECT * FROM exam_result WHERE (chinese > 80 or math>70) and english > 70;
(5) BETWEEN … AND …
-- 查询语文成绩在 [80, 90] 分的同学及语文成绩
SELECT name, chinese FROM exam_result WHERE chinese BETWEEN 80 AND 90;-- 使用 AND 也可以实现
SELECT name, chinese FROM exam_result WHERE chinese >= 80 AND chinese<= 90;
(6)IN
-- 查询数学成绩是 58 或者 59 或者 98 或者 99 分的同学及数学成绩
SELECT name, math FROM exam_result WHERE math IN (58, 59, 98, 99);-- 使用 OR 也可以实现
SELECT name, math FROM exam_result WHERE math = 58 OR math = 59 OR math= 98 OR math = 99;
1.
-- % 匹配任意多个(包括 0 个)字符
SELECT name FROM exam_result WHERE name LIKE '孙%';-- 匹配到孙悟空、孙权
补:
SELECT name FROM exam_result WHERE name LIKE '%孙'--匹配到以孙结尾的;
SELECT name FROM exam_result WHERE name LIKE '%孙%'--匹配到有孙的;
-- _ 匹配严格的一个任意字符
SELECT name FROM exam_result WHERE name LIKE '孙_';-- 匹配到孙权
SELECT name FROM exam_result WHERE name LIKE '孙__';-- 匹配到孙悟空
2.IS [NOT] NULL
-- 查询 qq_mail 已知的同学姓名
SELECT name, qq_mail FROM student WHERE qq_mail IS NOT NULL;-- 查询 qq_mail 未知的同学姓名
SELECT name, qq_mail FROM student WHERE qq_mail IS NULL;
此处再把‘=’与‘<=>’区分
(8)分页查询:LIMIT
select 列名,……from 表名 limit 数字 offset 数字;
limit 数字:最多筛选几条。
offset 数字:从哪条开始筛选。
-- 第 1 页
SELECT id, name, math, english, chinese FROM exam_result ORDER BY id LIMIT 3
OFFSET 0;-- 第 2 页
SELECT id, name, math, english, chinese FROM exam_result ORDER BY id LIMIT 3
OFFSET 3;-- 第 3 页,如果结果不足 3 个,不会有影响
SELECT id, name, math, english, chinese FROM exam_result ORDER BY id LIMIT 3
OFFSET 6;
-- 将孙悟空同学的数学成绩变更为 80 分
UPDATE exam_result SET math = 80 WHERE name = '孙悟空';-- 将曹孟德同学的数学成绩变更为 60 分,语文成绩变更为 70 分
UPDATE exam_result SET math = 60, chinese = 70 WHERE name = '曹孟德';-- 将总成绩倒数前三的 3 位同学的数学成绩加上 10 分
UPDATE exam_result SET math = math + 30 ORDER BY chinese + math + english LIMIT
3;-- 将所有同学的语文成绩更新为原来的 0.5 倍
UPDATE exam_result SET chinese = chinese * 2;
以上指令全部执行。
注意:
1.存在数据上限的问题,超过上限则会报错。
-- 删除孙悟空同学的考试成绩
DELETE FROM exam_result WHERE name = '孙悟空';
注意:
(1)
(2)
以上为我个人的小分享,如有问题,欢迎讨论!!!
都看到这了,不如关注一下,给个免费的赞