Mysql 基本查询详解

前面三篇文章我们已经详细谈了数据库形式上的基本内容,接下来让我们一起学习对数据库内数据的基本的操作吧!

1.对表的增删查改

1.1Create(增)

①语法:

insert into table_name [(column [, column] ...)] values (value_list)

, (value_list)\] ... value_list: value, \[, value\] ...

\]内的内容可以省略; #### ② 单行数据插入 ![](https://i-blog.csdnimg.cn/direct/16d5412b68124f8192e07ca0a9810ad2.png) #### ③ 全列插入 ![](https://i-blog.csdnimg.cn/direct/189bdf181d194f55bf4402b483c21a73.png) #### ④多行+全列插入 ![](https://i-blog.csdnimg.cn/direct/f6c45880cbe44411870f930c60f539b5.png) #### ⑤ 多行指定列插入 ![](https://i-blog.csdnimg.cn/direct/13a3438d571a47bf9b752fa5a7ed2c88.png) #### ⑥插入时更新插入 也就是说,如果你插入的内容不存在就插入,存在就更新这个数据; -- 主键冲突 INSERT INTO students (id, sn, name) VALUES (100, 10010, '唐大师'); ERROR 1062 (23000): Duplicate entry '100' for key **'PRIMARY' -\>主键冲突** -- 唯一键冲突 INSERT INTO students (sn, name) VALUES (20001, '曹阿瞒'); ERROR 1062 (23000): Duplicate entry '20001' for key **'sn' -\> 唯一键冲突** ![](https://i-blog.csdnimg.cn/direct/a540324f40cc432c8b6fb59402cbb5bc.png) ![](https://i-blog.csdnimg.cn/direct/21946ecd9e194ee797944420351c3d9c.png) #### ⑦ 替换 ![](https://i-blog.csdnimg.cn/direct/e1b7257b58ff4f9da90318b3b6591052.png) 特点就是有冲突也会直接替换;和上面的一样; ![](https://i-blog.csdnimg.cn/direct/b6f5734286134a9d90098c9a9da55b3f.png) ### ![](https://i-blog.csdnimg.cn/direct/79f6f40a3f6a497bb6b3e6e0a1d88d52.png)1.2查询 #### ① 全列查询 ![](https://i-blog.csdnimg.cn/direct/bb5ed555717e463c8e8867ae3eeb9fc3.png) \* 是通配符,但是在工作中我们不建议使用\*,因为数据太多了; #### ②指定列查询 ![](https://i-blog.csdnimg.cn/direct/50c5c45453d64b29b8c4c6024312f677.png) #### ③ selsect 查询时带表达式 ![](https://i-blog.csdnimg.cn/direct/99c1b54dc50c451183b53833e138326f.png) ![](https://i-blog.csdnimg.cn/direct/12694b574cf045fe90c22f0f107a9b26.png) ![](https://i-blog.csdnimg.cn/direct/62b4c34b41e742d690aff70754cac5e7.png) ![](https://i-blog.csdnimg.cn/direct/84e1f8bf9fcf4242b2715cd6e8af24b0.png) #### ④ 对筛选结果去重 ![](https://i-blog.csdnimg.cn/direct/ac47a3175f9b449590cdb8ede1e07381.png) #### ⑤ 按条件筛选(where字句) 就像我们之前学的if语句 在mysql中NULL就是NULL,0就是0; ![](https://i-blog.csdnimg.cn/direct/24ddfe2b74274d1cadb58884a609fc3e.png) NULL在单等号中没有办法比价; ![](https://i-blog.csdnimg.cn/direct/b151c030d0df415b874f697d1c950d89.png) select......where ......from ...... ![](https://i-blog.csdnimg.cn/direct/53648840a0234b21b6850b0d6dca1521.png) ![](https://i-blog.csdnimg.cn/direct/6bf7907a0af84c4dbea1ee257ddd3920.png) ![](https://i-blog.csdnimg.cn/direct/1f84b5e2a3514363975b5702672e7606.png) ![](https://i-blog.csdnimg.cn/direct/84815c76604a4b33a017dc5347235427.png) ![](https://i-blog.csdnimg.cn/direct/d91d3c1552db4cec8a56877d460b7059.png) ![](https://i-blog.csdnimg.cn/direct/835782bf46664acca62da2e8b742f07e.png) ![](https://i-blog.csdnimg.cn/direct/197cb544088a4e0c8871c4e942f27460.png) ![](https://i-blog.csdnimg.cn/direct/c5fafe2f9fcc4daea486195d9b38b40a.png) ![](https://i-blog.csdnimg.cn/direct/848905173d304e02abbe7d03c1c52840.png) #### ⑥ 模糊匹配(%) ![](https://i-blog.csdnimg.cn/direct/4e6f3f26eb314df8a9311b0a60252214.png) ![](https://i-blog.csdnimg.cn/direct/12ab8461705a42fe8491909b98460f93.png) #### ⑦ 结果排序 ![](https://i-blog.csdnimg.cn/direct/a3bf17c49cd24ac6ada423a3197f7baa.png) -- ASC 为升序(从小到大) -- DESC 为降序(从大到小) -- 默认为 ASC --NULL被认为比任何值都要小 ![](https://i-blog.csdnimg.cn/direct/35b85d67e794409e9648de04f9934583.png) ![](https://i-blog.csdnimg.cn/direct/9ba8f9d8e97b4a3fa1c593c5e3668d65.png) 如果数学相等,再按照英语升序的方式,以此类推; ![](https://i-blog.csdnimg.cn/direct/df9f3fca8bad42409ac843e392dc3823.png) ![](https://i-blog.csdnimg.cn/direct/51656d8cb0014202aa2bc58698cc39a5.png) #### ⑧ limit ![](https://i-blog.csdnimg.cn/direct/08be756c519947fdbc7870bc45b3f9e5.png) ![](https://i-blog.csdnimg.cn/direct/5bc9965670ca40f2a9cb2b125531b158.png) #### ⑨去重筛选 ![](https://i-blog.csdnimg.cn/direct/7dc7dde7f818483ea7456e4898915c12.png) ### ![](https://i-blog.csdnimg.cn/direct/79f6f40a3f6a497bb6b3e6e0a1d88d52.png)1.3更新(update) #### ① 语法 > UPDATE table_name SET column = expr \[, column = expr ...\]\[WHERE ...\] \[ORDER BY ...\] \[LIMIT ...

对查询到的结果进行列值更新

② 基本使用

③复杂使用

更新全表的语句慎用!

1.4 delete(只能删除数据,不会删除结构)

①删除数据

② 删除整张表

sql 复制代码
delete from +table_name;

③ truncate 截断表

sql 复制代码
truncate from tablename;

注意:

只能对整表操作,不能像 DELETE 一样针对部分数据操作;

实际上 MySQL 不对数据操作,所以比 DELETE 更快,但是TRUNCATE在删除数据的时候,并不经过真正的事物,就是不会保留痕迹;所以无法回滚;

会重置 AUTO_INCREMENT 项;

1.5插入查询结果

① 语法

sql 复制代码
INSERT INTO table_name [(column [, column ...])] SELECT ...

②案例

1.6聚合统计

① 聚合函数

② 使用

A. count
B.sum
C.avg
D.max

1.7 分组

最后总是为了聚合统计;

① 语法

sql 复制代码
select column1, column2, .. from table group by column;

② 使用

③having

对聚合后的统计数据进行统计;

④having 和 where的区别

其实没做分组也可以看成一个组;

=========================================================================

相关推荐
X-⃢_⃢-X2 小时前
八、Redis之BigKey
数据库·redis·缓存
~莫子2 小时前
Redis
数据库·redis·缓存
历程里程碑2 小时前
36 Linux线程池实战:日志与策略模式解析
开发语言·数据结构·数据库·c++·算法·leetcode·哈希算法
颜颜yan_2 小时前
从千毫秒到亚毫秒:连接条件下推如何让复杂 SQL 飞起来
数据库·sql
ChaITSimpleLove2 小时前
如何查看系统中 PostgreSQL 数据库的进程(postgres)运行状态?
数据库·postgresql·查看pgsql运行状态·pgsql进程运行状态·postgres 进程·tree 树形结构
ChaITSimpleLove2 小时前
PostgreSQL 部署与运维常用命令详解
运维·数据库·postgresql·部署·命令解析
ChaITSimpleLove2 小时前
PostgreSQL 的 SQL 执行过程详解
数据库·sql·postgresql·词法分析·语法分析·执行过程
小鸡脚来咯2 小时前
SQL表连接
java·开发语言·数据库
Henray20242 小时前
SQL 窗口函数
大数据·数据库·sql