Welcome 微信登录

首页 / 数据库 / MySQL / Oracle批量update

需求:将t2(t_statbuf)表中id和t1(T_Mt)表相同的记录更新进t1表。1.错误的写法:[sql]
  1. update table_name t1 set (a,b,c)=( select a,b,c from table_name_2 t2 where t1.a=t2.a);  
这种写法,会更新t1表中的所有行:如果t1.a=t2.a的,就更新t2中查出的记录进t1;如果t1.a<>t2.a的,t1中的记录会被更新成空(null)。正确的写法:[sql]
  1. update table_name t1 set (a,b,c)=( select a,b,c from table_name_2 t2 where t1.a=t2.a) where exists(select 1 from table_name_2 t2 where t1.a=t2.a);  
解析:正确的写法,就是在后面加了一句 where exists(select 1 from table_name_2 t2 where t1.a=t2.a);这句话的意思是:如果存在t1.a=t2.a,就更新,否则,不更新,所以不会导致t1表中所有的记录都被更新。例:update table_name_1 set (a,b) = (select 1,2 from dual where 1=2);这个结果会把table_name_1中的记录全部更新成空(null),因为后面1=2不成立。总结:update时,要弄清限定条件,要测试!我的测试语句:[sql]
  1. update my_time_test1 t1 set (MDATE,DISCRIPT) =(select MDATE,DISCRIPT from   
  2.   my_time_test t2 where t1.DISCRIPT=t2.DISCRIPT) where exists (select 1 from   
  3.   my_time_test t2 where t1.DISCRIPT=t2.DISCRIPT);  
我的业务语句:[sql]
  1. update T_Mt t1 set (Stat,OStat,RptTime) =(  
  2.  select Stat,Stat,RptTime from t_statbuf t2 where t1.MsgId=t2.MsgId) where exists(  
  3.  select 1 from t_statbuf t2 where t1.MsgId=t2.MsgId);  --如果存在t1和t2相等的,就更新。不加where exists,是不管存不存在,都更新,不存在的,结果会被更新成空,但是那条记录还在  
Oracle中substr函数的用法(sqlserver right)Oracle sql%rowcount 返回影响行数相关资讯      Oracle基础教程 
  • Oracle块编程返回结果集详解  (11/10/2013 10:45:58)
  • Oracle基础教程之设置系统全局区  (08/22/2013 14:24:00)
  • Oracle基础教程知识点总结  (06/18/2013 07:43:32)
  • Oracle基础教程之tkprof程序详解  (10/22/2013 11:49:50)
  • Oracle基础教程之sqlplus汉字乱码  (07/18/2013 16:30:00)
  • Oracle 管理之 Linux 网络基础  (02/16/2013 18:37:35)
本文评论 查看全部评论 (0)
表情: 姓名: 字数