04-增删查改数据表
添加数据
1
| insert into 表名 [(字段名 [,字段名] ...)] values (值的列表)
|
插入数据
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| insert into demo.goodsmaster2 ( itemnumber, barcode, goodsname, specification, uint, price )values ( 4, '0003', '尺子', '三角型', '把', 5 );
|
data:image/s3,"s3://crabby-images/37c63/37c634dd84e371cb3f0ac4da414621a072658765" alt="image-20230116225511515"
只给三个字段
1 2 3 4 5 6 7 8 9 10 11 12 13
| INSERT INTO demo.goodsmaster ( -- 这里只给3个字段赋值,itemnumber、specification、unit不赋值 barcode, goodsname, price ) VALUES ( '0004', '测试', 10 );
|
data:image/s3,"s3://crabby-images/764e8/764e875613e663049f33e7da3efef50a2f47b4dd" alt="image-20230116225652251"
插入数据记录时,必须考虑的三种字段约束
- 字段允许为空,赋值时可以为空值
- 字段是主键,不能为空
- 字段定义不能为空,且不是主键,就必须按照添加的约束进行处理
尝试将specification
改为不能为空
1 2
| ALTER TABLE demo.goodsmaster MODIFY specification TEXT NOT NULL;
|
报错:
data:image/s3,"s3://crabby-images/88469/88469c46f498cd35ae7c50a42ece0d6b3cc2121e" alt="image-20230116230015683"
因为有部分数据的specification
是null,所以不能修改,除非删除null数据
插入查询结果
1 2 3 4
| insert into 表名 select 字段名或值 from 表名 where 条件
|
删除数据
为了防止误删,习惯性添加where
语句
删除所有数据
1 2
| delete from demo.goodsmaster where itemnumber > 1;
|
修改数据
1 2 3
| update 表名 set 字段名=值 where 条件
|
注意:不要修改主键字段的值
修改主键字段的值会有怎样的结果?
data:image/s3,"s3://crabby-images/44f9a/44f9ada4a7c896474eb4d8f07886360376001042" alt="image-20230116230701050"
1 2 3
| update demo.goodsmaster set itemnumber = 10 where itemnumber = 3;
|
data:image/s3,"s3://crabby-images/8030d/8030d11508ea231c59df06d95c1676cdf9b8c40a" alt="image-20230116230857625"
找不到原来的数据了
data:image/s3,"s3://crabby-images/020c4/020c43b62cce4ca2ef49e6d5afff03b694fb0c0b" alt="image-20230116230930439"
查询数据
1 2 3 4 5 6 7
| select *|字段列表 from 数据源 where 条件 group by 字段 having 条件 order by 字段 limit 起始点,行数
|
select
:查询关键字 ,*
是通配符,查询所有字段
where
:查询条件
group by
:查询结果如何分组,经常与Mysql的聚合函数一起使用
having
:筛选查询结果,跟where
类似
FROM
FROM关键字表示查询的数据源,数据源不一定是表,也可以是查询结果
1 2 3 4 5
| select a.goodsname,a.price from( select * from demo.goodsmaster )as a;
|
data:image/s3,"s3://crabby-images/443bb/443bb6c9677127673c8ec28e3015f71a8d380b12" alt="image-20230116234258076"
红色框里的部分叫做派生表(derived table)或者自查询(subquery)
ORDER BY
ASC表示生序,DESC表示降序
1 2 3
| select * from demo.goodsmaster order by barcode ASC,price DESC;
|
不加order,查询
data:image/s3,"s3://crabby-images/1fadd/1faddf01e17937b9dc8d230534cd4dc5738e80b9" alt="image-20230116234557128"
加order,查询
data:image/s3,"s3://crabby-images/2216d/2216d39b834869b4a131711913a426159b2f1f89" alt="image-20230116234621252"
LIMIT
1 2 3
| select * from demo.goodsmaster limit 1,2
|
起始位2,结束为3
data:image/s3,"s3://crabby-images/bbc44/bbc4478387db9c90defde9ca7ae4041dff719577" alt="image-20230116234828638"
处理重复信息
将B的数据插入A中,解决重复信息
1 2 3 4
| insert into demo.goodsmaster select * from demo.goodsmaster2 as a on duplicate key update barcode = a.barcode,goodsname=a.goodsname;
|
表A
data:image/s3,"s3://crabby-images/d5225/d52252b74adb4a367ffd83704aaab1caed87a465" alt="image-20230117000446369"
表B
data:image/s3,"s3://crabby-images/f4963/f4963ed8cdd284e03a66e85ffd0129597c4662f4" alt="image-20230117000605687"
data:image/s3,"s3://crabby-images/24c38/24c38c39c3fc457178f19bfbab1b076001750c44" alt="image-20230117000709963"