oracle update语句的复杂写法,求大神
例如:update表asetcasewhen表b='2'thena.aa=b.bbend...
例如:update 表a set case when 表b='2' then a.aa=b.bb end
展开
3个回答
展开全部
好像是
一条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不能省略,否则会导致没有对应关系的数据修改错误,甚至会报错。
一条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吧。
追答
不能
展开全部
表b='2'是什么意思?这个UPDATE对表a没有任何限制,结果是把表a的全部aa字段都更新了,而且a.aa=b.bb这句很可能导致返回多行的错误,
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
更新语句,用不了case when
a表没条件,会全部更新的
a表没条件,会全部更新的
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询