Mysql 基本查询详解

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

1.对表的增删查改

1.1Create(增)

①语法:

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

, (value_list) ...

value_list: value, , value ...

\[\]内的内容可以省略;

② 单行数据插入

③ 全列插入

④多行+全列插入

⑤ 多行指定列插入

⑥插入时更新插入

也就是说,如果你插入的内容不存在就插入,存在就更新这个数据;

-- 主键冲突

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' -> 唯一键冲突

⑦ 替换

特点就是有冲突也会直接替换;和上面的一样;

1.2查询

① 全列查询

* 是通配符,但是在工作中我们不建议使用*,因为数据太多了;

②指定列查询

③ selsect 查询时带表达式

④ 对筛选结果去重

⑤ 按条件筛选(where字句)

就像我们之前学的if语句

在mysql中NULL就是NULL,0就是0;

NULL在单等号中没有办法比价;

select......where ......from ......

⑥ 模糊匹配(%)

⑦ 结果排序

-- ASC 为升序(从小到大)

-- DESC 为降序(从大到小)

-- 默认为 ASC

--NULL被认为比任何值都要小

如果数学相等,再按照英语升序的方式,以此类推;

⑧ limit

⑨去重筛选

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的区别

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

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

相关推荐
摇滚侠4 小时前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
麦聪聊数据6 小时前
数据服务化时代:企业数据能力输出的核心路径
数据库
ApacheSeaTunnel6 小时前
实战演示 | 基于 Apache SeaTunnel 与 Apache DolphinScheduler 实现 MySQL 到 Doris 离线定时增量同步
大数据·mysql·开源·doris·数据集成·seatunnel·数据同步
shushangyun_6 小时前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡7 小时前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧7 小时前
Oracle EXPLAIN PLAN
数据库·oracle
BD_Marathon7 小时前
SQL学习指南——视图
数据库·sql
活宝小娜7 小时前
mysql详细安装教程
数据库·mysql·adb
贤时间7 小时前
codex 助力oracle ebs 开发
数据库·oracle
秉承初心8 小时前
PostgreSQL 数据性能瓶颈突破实战
数据库·postgresql·oracle