更新表数据的那些事—DML之update

在web项目开发中,离不开对数据库的操作,最近处理数据比较多,分享一下update的使用心得,其实主要是update 和 select 相结合。小生初入门,不充分的地方,欢迎更多的朋友帮忙补充。有遗漏的地方,还望勿喷,大家互相学习交流。

1. 想更新一张表A的某个字段a_name,值来自另外一张表B的b_name,两个表有关系。那么一个sql就可以搞定全表,update同时操作两张表:
update A a, B b
set a.a_name = b.b_name
where a.id = b.id;

以上需求也可以这样实现:
update A a,(select * from B) b
set a.a_name = b.b_name
where a.id = b.id;

2. 有的情形是表的自关联,即更新一张表的某个字段,条件是该表的另一个字段:
其实和上一种情况类似,但就得用情形1的下面那个方法了。
这里再来个新颖的形式,即把查询的结果,直接作为值执行sql语句:
update table1 p1 set p1.attribute_id = (select p2.id
from table1 p2 where p1.attribute_name = p2.display_name
)

3. 更新全表的数据,但不是一刀切,即根据现有字段的意义来判断更新什么值。那么我们可以在set后面添加某些函数的。

update product set attr= decode ( type ,0,'ZS' ,1 ,'ZZ');
该语句应该不难理解,当type=1时,set attr='ZS', ……

类似这种的,还有很多其他函数,比如replace:
update table set name=replace(keyword_name,'tmall,'yhd);
即将表的keyword_name字段里面的‘tmall’ 全部替换成‘yhd’,然后更新。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值