oracle update from

UPDATE (SELECT /*+ BYPASS_UJVC */ sys_users.DEPARTMENT_ID sysvalue,v_users.DEPARTMENT_ID vvalue FROM sys_users,v_users WHERE sys_users.ID=v_users.person_id and v_users.DEPARTMENT_ID != sys_users.DEPARTMENT_ID) SET sysvalue=vvalue

 

 

/*+ BYPASS_UJVC */ 是oracle的一种写法,大意是跳过唯一性检查,强制执行更新。如果没有这一段,可能无法执行这条sql。当然加上这一段就有可能对同一条记录更新多次,特定情况下会有不可预知的影响。

 

 

如何相连接的表之间有主外键关系。则不需要增加/*+ BYPASS_UJVC */  。否则,oracle会报错.

posted on 2009-06-25 15:45 肖雪 阅读(168) 评论(0)  编辑  收藏


只有注册用户登录后才能发表评论。


网站导航:
 
<2009年6月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

导航

统计

常用链接

留言簿(1)

随笔档案

搜索

最新评论

阅读排行榜

评论排行榜