oracle update语句的复杂写法,求大神

例如:update表asetcasewhen表b='2'thena.aa=b.bbend... 例如:update 表a set case when 表b='2' then a.aa=b.bb end 展开
 我来答
dngoryaner
2012-12-27 · TA获得超过2350个赞
知道小有建树答主
回答量:2404
采纳率:0%
帮助的人:1141万
展开全部
好像是
一条update只能修改一张表里的字段,但是可以关联多张表去修改。不知道你用的是什么数据库。
常用的sqlserver格式如下:
update table1 set a.字段1=b.字段1,....,a.字段N=b.字段N from table1 a,table2 b where 两个表的关联字段。
常用的oracle格式如下:
update table1 a set (a.字段1,....,a.字段N) =(select b.字段1,...,b.字段N from table2 b where 两个表的关联字段) where exists (select 1 from table2 b where 两个表的关联字段)。
注意oracle语句里的exists不能省略,否则会导致没有对应关系的数据修改错误,甚至会报错。
追问
oracle 不能使用update from吧。
追答
不能
ct2k01
2012-12-27 · TA获得超过1570个赞
知道小有建树答主
回答量:1653
采纳率:0%
帮助的人:1114万
展开全部
表b='2'是什么意思?这个UPDATE对表a没有任何限制,结果是把表a的全部aa字段都更新了,而且a.aa=b.bb这句很可能导致返回多行的错误,
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
bd9006
2012-12-27 · TA获得超过2.5万个赞
知道大有可为答主
回答量:4.8万
采纳率:63%
帮助的人:1.6亿
展开全部
更新语句,用不了case when

a表没条件,会全部更新的
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式