更新表数据的那些事—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’,然后更新。

猜你喜欢

转载自xiao-2012-wei.iteye.com/blog/1955968