MySQL表的增删改查(基础)

目录

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)


1.新增

1.1单行数据 +全列插入

insert into 表名 values(列,列……);

注意:

这里给出的列的数目和类型,都要和表结构相匹配。 

1.2多行数据 + 全列插入

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);

 1.3指定插入

 insert into 表名(列……)values(列,列……),(列,列……)……;

思考:

比如,现在我想要插入10行数据,我有两种操作。

(1)写一条SQL语句,一次性插入10条。

 (2)写十条SQL语句,插10次。

结论:第一种方式的执行效率要比 第二种方式的执行效率高。

MySQL表的增删改查(基础)_第1张图片

MySQL表的增删改查(基础)_第2张图片


 2.查询

2.1全列查询

select * from 表名

注意:通常情况下不建议使用 * 进行全列查询

以例题1.1为例。

MySQL表的增删改查(基础)_第3张图片
查询的列越多,意味着需要传输的数据量越大;

一旦数据过大,此时这个操作就会产生大量的硬盘IO和网络IO,就可能会把硬盘或网卡的宽带给吃满(吃满可以理解成堵车)。

一旦宽带吃满,此时服务器就无法正常响应,其他客户的请求。

思考:

那我可以强制停止吗?

强制停止本质上也是通过客户端给服务器发出一个“停止”请求,但应此时宽带吃满了,“停止”请求也被堵在半路上。 

2.2指定列查询 

只查询你指定列查询 

select 列名…… from 表名

指定列的顺序不需要按定义表的顺序来 

但是,这种查询也不是万无一失的。

虽然你查询的列数可能很少,但你查询的列的行数很多,此时也可能 宽带吃满。

 2.3查询字段为表达式

select 表达式 from 表名

细节:

以例题1.1为例。

MySQL表的增删改查(基础)_第4张图片

 2.4别名

为查询结果中的列指定别名,表示返回的结果集中,以别名作为该列的名称

 select 表达式 (as) 别名 from 表名 

 例如:

-- 结果集中,表头的列名 = 别名
SELECT id, name, chinese + math + english 总分 FROM exam_result;

 2.5 去重

使用 DISTINCT 关键字对某列数据进行去重:
select distinct 列名,……from 表名

例如:

 以例题1.1为例。

MySQL表的增删改查(基础)_第5张图片

 2.6排序

select 列名,……from 表名 order by 列名,……;

注意:

1. 没有 ORDER BY 子句的查询,返回的顺序是未定义的,永远不要依赖这个顺序 。

2. NULL 数据排序,视为比任何值都小,升序出现在最上面,降序出现在最下面。
3.无特殊说明默认为 升序。
降序:~~order by 列名 desc;
此时的desc=>descand 降序的意思。
4.字符比大小是按“字典序”排序的。
5. 可以对多个字段进行排序,排序优先级随书写顺序。
意思为,order by指定多个列时是带优先级的,前面的列优先级高,后面的列优先级低。
优先级高的列的值相同,才会比较优先级低的列。

对于注意3,5的举例:

 以例题1.1为例。

MySQL表的增删改查(基础)_第6张图片

 MySQL表的增删改查(基础)_第7张图片 2.7条件查询

select 列名,……from 表名 where 条件;

比较运算符:

MySQL表的增删改查(基础)_第8张图片

逻辑运算符:

MySQL表的增删改查(基础)_第9张图片

注意事项:

  1. WHERE条件可以使用表达式,但不能使用别名。

  2. AND的优先级高于OR,在同时使用时,需要使用小括号()包裹优先执行

 利用举例补充注意事项

以下均与例题1.1为例。

(1)一般使用:查询英语不及格的同学及英语成绩 ( < 60 )

MySQL表的增删改查(基础)_第10张图片

 (2)查询语文成绩好于英语成绩的同学

MySQL表的增删改查(基础)_第11张图片

进行比较的时候,不仅仅是一个列和常量的比较,也可以是两个列或多个列的比较。

(3)查询总分在 200 分以下的同学

 WHERE条件可以使用表达式,但不能使用别名

MySQL表的增删改查(基础)_第12张图片

正确:

MySQL表的增删改查(基础)_第13张图片

 (4)AND与OR

1.一般使用:

-- 查询语文成绩大于80分,且英语成绩大于80分的同学
SELECT * FROM exam_result WHERE chinese > 80 and english > 80;

MySQL表的增删改查(基础)_第14张图片

-- 查询语文成绩大于80分,或英语成绩大于80分的同学
SELECT * FROM exam_result WHERE chinese > 80 or english > 80;

MySQL表的增删改查(基础)_第15张图片

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;

MySQL表的增删改查(基础)_第16张图片

(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;

MySQL表的增删改查(基础)_第17张图片

(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;

MySQL表的增删改查(基础)_第18张图片 (7)模糊查询:LIKE

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;

此处再把‘=’与‘<=>’区分

MySQL表的增删改查(基础)_第19张图片

 (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;

MySQL表的增删改查(基础)_第20张图片


3.修改(Update

MySQL表的增删改查(基础)_第21张图片

-- 将孙悟空同学的数学成绩变更为 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;

以上指令全部执行。 

MySQL表的增删改查(基础)_第22张图片

注意:

1.存在数据上限的问题,超过上限则会报错。

 2.MySQL表的增删改查(基础)_第23张图片


 4.删除(Delete

MySQL表的增删改查(基础)_第24张图片

-- 删除孙悟空同学的考试成绩

DELETE FROM exam_result WHERE name = '孙悟空'; 

注意:

(1)

(2) 

MySQL表的增删改查(基础)_第25张图片


以上为我个人的小分享,如有问题,欢迎讨论!!! 

都看到这了,不如关注一下,给个免费的赞 

你可能感兴趣的:(mysql,mysql,java,数据库,sql,经验分享)