怎样将Oracle一张表的多个字段更新到另一张表中去

原创 2012年12月29日 20:22:43

假设表a中有多个字段(province ,city)需要从b表获取(两张表的mobile一样),总结了几种写法。

 

一、update a  set a.province=(select province from b where b.mobile=a.mobile);

        update a  set a.city=(select cityfrom b where b.mobile=a.mobile);

 

这种写法效率太低,尤其是号码有上万条的时候,所以抛弃。

 

二、update a set a.province=b.province,a.city=b.city from a  inner join b on a.mobile=b.mobile.

      或者update a set a.province=b.province,a.city=b.city from a,b where a.mobile=b.mobile.

 

三、update a inner join b on a.mobile=b.mobile set a.province=b.province,a.city=b.city 

注意:第二种和第三种写法在oracle行不通的,老是报错,折腾了好长时间,最后还是用下面的语句解决了问题

 

四、update a set(a.province,a.city)=(select province,city from b where b.mobile=a.mobile)  

其实第四种方法是第一种方法的合并。

 

项目中写的真实例子:
update m_smsphoneno a set (a.operator,a.province,a.city)=(select  OWNER,STATE,CITY from keyaccount.CELLPHONESORT b where substr(a.mobile,1,7)=b.startcode)  where  a.category=2 and a.city is null;   注:用a.city=null不行的

 

 


 

 

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

Oracle 将一张表的数据更新到另一张表

需求 有表成绩T1,记录学生成绩,表T2是一张加分的表,现在用表T2给少数名族学生加分。 表成绩表T1 PID SCORE ISMINORITY ---- ---------- ----...

Oracle多表关联更新(update多表关联)

转自:http://blog.163.com/gaofx_hk/blog/static/193999289201172893813254/ .Oracle没有update from语法,可以通过两种...

Oracle中用一个表的数据更新另一个表的数据

转自:http://www.2cto.com/database/201205/130987.html有下面两个表:将表tab1中id值与和表tab2中id值相同的行的val更新为tab2中val的值....

MVC Html.AntiForgeryToken() 防止CSRF攻击 --MVC笔记

(一)MVC Html.AntiForgeryToken() 防止CSRF攻击 MVC中的Html.AntiForgeryToken()是用来防止跨站请求伪造(CSRF:Cross-site req...

MVC Html.AntiForgeryToken() 防止CSRF攻击

(一)MVC Html.AntiForgeryToken() 防止CSRF攻击 MVC中的Html.AntiForgeryToken()是用来防止跨站请求伪造(CSRF:Cross-site req...

ASP.NET MVC3 类面向切面AOP 的Filter操作

在开发大项目的时候总会有相关的AOP面向切面编程的组件,而MVC(特指:Asp.Net MVC,以下皆同)项目中不想让MVC开发人员去关心和写类似身份验证,日志,异常,行为截取等这部分重复的代码,那我...
  • jurken
  • jurken
  • 2014-11-14 11:54
  • 1407

SVN常用命令之checkout

官方解释,请参考:http://www.subversion.org.cn/svnbook/nightly/svn.ref.svn.c.checkout.html 常用检出命令: svn co h...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)