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

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