前面三篇文章我们已经详细谈了数据库形式上的基本内容,接下来让我们一起学习对数据库内数据的基本的操作吧!
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的区别
其实没做分组也可以看成一个组;

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