好问题
Good  Question
  • 首 页
  • 问题
    • PHP
    • JAVA
    • CPlusPlus
    • C#
    • SQL
  • 关 于
  • 联 系
在SQL中如何使用join做一个更新声明 关闭 返回上一级  

在SQL中如何使用join做一个更新声明
+ 查看更多

发布日期:2018-02-23 09:58
分类:SQL
浏览次数:90
问题描述:在sql server 2005我需要使用一个父表更新一个表,如下:
sale
id (int)
udid (int)
assid (int)
ud
id  (int)
assid  (int)
sale.assid 包含更新ud.assid的当前值,什么语句可以做这个,我想应该是join 但我不确定
 
 
回答:
 
这里有不同DBMS的不同方法,但是如果你使用以下几种DBMS以外的方法,只能使用ISO标准方法。
 
ANSI/ISO:
update ud 
  set assid = (
               select sale.assid 
                 from sale 
                where sale.udid = ud.id
              )
 where exists (
               select * 
                 from sale 
                where sale.udid = ud.id
              );
MySQL:
update ud u
inner join sale s on
    u.id = s.udid
set u.assid = s.assid
SQL Server:
update u
set u.assid = s.assid
from ud u
    inner join sale s on
        u.id = s.udid
Oracle:
update
    (select
        u.assid as new_assid,
        s.assid as old_assid
    from ud u
        inner join sale s on
            u.id = s.udid) up
set up.new_assid = up.old_assid
上一篇怎么才能把多个元组的数据集中到一个中去?
问题:在Oracle中获取所有表目录?下一篇
下一篇问题:在Oracle中获取所有表目录?

最新文章

  • 函数`__construct`用来干嘛的
    发布日期:2018-03-26
  • 通过访客的IP得到他们的地区
    发布日期:2018-03-26
  • 合并两个PHP对象的最好的方法是什么?
    发布日期:2018-03-26
  • 该如何把一该如何把一个对象转化成数组?
    发布日期:2018-03-26
  • 什么是输出缓冲区?
    发布日期:2018-03-26
  • 在PHP中怎么把用逗号分隔的字符串分隔在一个数组里?
    发布日期:2018-03-26
  • 在PHP中使用foreach循环时查找数组的最后一个元素
    发布日期:2018-03-26
关于好问
收集整理一些有用的问题和回答,造福中国的程序旺和IT喵们!
友情链接
起飞页 
相关信息
版权声明
Copyright © 2016 - 2022  苏州卡达网络科技有限公司 备案号:苏ICP备09008221号