zoukankan      html  css  js  c++  java
  • plsql 跨表 update

        接到新任务,对比两个程序、不同数据库、不同数据表、不同字段的值。

    接到任务第一想法,如果我用一条sql搞定这个超跨区任务是不是很 NB。

    很快,我就放弃了这个想法。毕竟,认清现实还是有必要的(一条sql横跨两台不同服务器,如有大神能做到,请指教 - )。

    一、先用 Navicat 工具下的 - 数据传输 : 把两个不同服务器下、不同数据库下、不同表,搞到同一个库内。

     

    到了同一数据库下,直面的问题就只有跨表修改这个问题了。

     

    在不知道可以跨表update的前提下,想到来个中间表,把需要对比的两个字段搞到一个表中,在进行修改操作。转念想想,这么做对比后的中间表要同步到被修改表时候,还是个跨表问题。

    二 、直接来吧 ~

     

    • 写个sql 试试 ~~ update + 两表名
    UPDATE so_equipment_manage so,
    t_s_category T 
    SET so.asset_name = T.NAME 
    WHERE
        so.asset_type = T.code 
        AND so.asset_name != T.NAME 
        AND so.asset_type = 'A06A01A03';

     

    运行结果:

     

    显然,上面这个sql 是不行的,update 后只能跟一个表名。 在逗号哪里就报错了。

     

    • 再试一次 ~ 写个子查询,把 对比表写到后面去
    UPDATE so_equipment_manage AS so 
    SET so.asset_name = (
    SELECT T
        .NAME 
    FROM
        t_s_category AS T 
    WHERE
        so.asset_type = T.code 
        AND so.asset_name != T.NAME 
        AND so.asset_type = 'A06A01A03' 
        );

     

     

    set 后 表别名字段不存在,删掉这个别名呢?

     

    • 再次运行 ~
    UPDATE so_equipment_manage AS so 
    SET asset_name = (
    SELECT T
        .NAME 
    FROM
        t_s_category AS T 
    WHERE
        so.asset_type = T.code 
        AND so.asset_name != T.NAME 
        AND so.asset_type = 'A06A01A03' 
        );

     

     

     

    此一修改,瞬间把 so_equipment_manage 表中 asset_name 字段全部改为 null 。

    惊出一身冷汗,瞬间都想到了老板的咆哮和辞退信,转念一想我这是测试数据。无量那个天尊,还好我习惯性谨慎。尝试sql前先备份出来一份环境,确定sql可用才在正式环境使用。

    【注:对于没有100%把握的sql,先使用测试数据库进行测试。 这个很重要!!!

    并尽量缩小修改范围,我的sql中 asset_type = 'A06A01A03' 这个条件是单独加的,仅仅对这一类数据进行尝试。即使这样,错误的sql 也会使得表内所有数据被修改。】

     

    • 子查询不通,在where条件前后加上 对比表。

    意不意外,成功了,哈哈哈 ~~~

     

    UPDATE so_equipment_manage so 
    SET asset_name = T.NAME 
    FROM
        t_s_category T 
    WHERE
        so.asset_type = T.code 
        AND so.asset_type = 'A06A01A03';

     

    • 最终 确定 跨表修改方式:

    upadte table1 t1 set 被修改字段 = t2.提供值字段 from table2 t2 where t1.value1 = t2.value2 ;

    重点:set 后 被修改字段不能用 【 别名.被改字段 】,这里的别名会被不识别而报错。

     

     

  • 相关阅读:
    Matlab 绘制三维立体图(以地质异常体为例)
    Azure DevOps的variable group实现array和hashtable参数的传递
    Azure DevOps 利用rest api设置variable group
    Azure AADSTS7000215 其中一种问题的解决
    Power BI 实现实时更新Streaming Dataset
    AAD Service Principal获取azure user list (Microsoft Graph API)
    Matlab 沿三维任意方向切割CT图的仿真计算
    Azure Powershell script检测登陆并部署ARM Template
    Azure KeyVault设置策略和自动化添加secrets键值对
    Azure登陆的两种常见方式(user 和 service principal登陆)
  • 原文地址:https://www.cnblogs.com/wgy1/p/10749884.html
Copyright © 2011-2022 走看看