一、插入数据
insert into table_name(column_list) values(value_list);
1.1 将查询结果插入表
insert into table_name(column_list) values select (cilomn_list) from t2 [where 条件查询语句];
二、更新数据
update table_name
set c1 = v1, c2 = v2
where 条件语句
2.1 几种批量更新方法
2.1.1 replace into 批量更新
replace into 跟 insert 功能类似,不同点在于:replace into 首先尝试插入数据到表中,
- 如果发现表中已经有此行数据(根据主键或者唯一索引判断)则先删除此行数据,然后插入新的数据。
- 否则,直接插入新数据。
要注意的是:插入数据的表必须有主键或者是唯一索引!否则的话,replace into 会直接插入数据,这将导致表中出现重复的数据。
replace into test_tbl(id,dr) values (1,'2'),(2,'3'),(3,'5');
2.1.2 insert into …on duplicate key update批量更新
replace into 和 insert into on duplicate key update的不同在于:
- replace into 操作本质是对重复的记录先delete 后insert,如果更新的字段不全会将缺失的字段置为缺省值
- insert into 则是只update重复记录,不会改变其它字段。
-- dr=values(dr);是需要更新的字段
insert into test_tbl(id,dr) values (1,'2'),(2,'3'),...(x,'y')
on duplicate key
update
dr=values(dr);
2.1.3 使用mysql 自带的语句构建批量更新
这句sql 的意思是,更新dingdan 字段,如果id=1 则dingdan 的值为3,如果id=2 则dingdan 的值为4……
where部分不影响代码的执行,但是会提高sql执行的效率。确保sql语句仅执行需要修改的行数,这里只有3条数据进行更新,而where子句确保只有3行数据执行。
UPDATE yoiurtable
SET dingdan = CASE id
WHEN 1 THEN 3
WHEN 2 THEN 4
WHEN 3 THEN 5
END
WHERE id IN (1,2,3)
三、删除数据
delete from table_name [where 条件语句]