oracle值sql记录

前言

由于本人sql比较薄弱 将一些常用又使用的sql语句记录与大家分享
一:替换特殊字符分割的字符串

需求如下:

有张原始表tschedule 和新表bjcodechange ,需要将原始表的compeny_code字段和bjcodechange 的oldwindcode 进行关联替换成bjcodechange表的newwindcode字段

无特殊字符的查询很简单 如下

sql 复制代码
UPDATE tschedule  ts
   SET ts.security_code =
       (SELECT bj.newwindcode
          FROM BJcodechange bj
         WHERE ts.security_code = bj.oldwindcode
           )
 WHERE EXISTS (SELECT 1
          FROM BJcodechange bj
         WHERE ts.security_code = bj.oldwindcode);

但是有特殊字符的数据如下 注意测试原始表的compeny_code字段的内容许如下所示

tschedule:

name compeny_code
张三 000001
李四 800981,000001,000002

bjcodechange:

oldwindcode newwindcode
800981 888888

最终的效果如下

name compeny_code
张三 000001
李四 888888 ,000001,000002

完整步骤

步骤1:拆分后的中间数据 (split_data)

rid elem ord
OKABKyAAA2AAAAiTAAD 000001 1
OKABKyAAA2AAAAiTAAD 800981 2
OKABKyAAA2AAAAiTAAD 000001 3
AABKyAAA2AAAAiTAAD 000002 1
步骤2:关联后的中间数据
rid elem newwindcode
---------------------- -------- -------------
OKABKyAAA2AAAAiTAAD 430017 920017
OKABKyAAA2AAAAiTAAD 000001 (null)
OKABKyAAA2AAAAiTAAD 430017 920017
AABKyAAA2AAAAiTAAD 000001 (null)
步骤3:聚合后的结果 (merged)
rid new_code
---------------------- ---------------------
OKABKyAAA2AAAAiTAAD 920017,000001,920017
AABKyAAA2AAAAiTAAD 000001
sql 复制代码
MERGE INTO tschedule a
USING (
  WITH split_data AS (
    SELECT 
      a.rowid AS rid, 
      regexp_substr(a.compeny_code, '[^,]+', 1, LEVEL) AS elem,
      LEVEL AS ord
    FROM tschedule a
    CONNECT BY 
      LEVEL <= regexp_count(a.compeny_code, ',') + 1
      AND PRIOR a.rowid = a.rowid
      AND PRIOR DBMS_RANDOM.VALUE IS NOT NULL
  )
  SELECT 
    rid,
    LISTAGG(NVL(b.newwindcode, elem), ',') WITHIN GROUP (ORDER BY ord) AS new_code 
  FROM split_data sd
  LEFT JOIN bjcodechange b ON sd.elem = b.oldwindcode  
  GROUP BY rid
) merged
ON (a.rowid = merged.rid)
WHEN MATCHED THEN
  UPDATE SET a.compeny_code = merged.new_code
WHERE a.compeny_code != merged.new_code;

好了 至此 oracle值sql记录 点点关注不迷路 老铁们!!!!!

相关推荐
星辰离彬27 分钟前
Java 与 MySQL 性能优化:MySQL连接池参数优化与性能提升
java·服务器·数据库·后端·mysql·性能优化
张璐月3 小时前
mysql join语句、全表扫描 执行优化与访问冷数据对内存命中率的影响
数据库·mysql
全干engineer5 小时前
ClickHouse 入门详解:它到底是什么、优缺点、和主流数据库对比、适合哪些场景?
数据库·clickhouse
Hellyc7 小时前
基于模板设计模式开发优惠券推送功能以及对过期优惠卷进行定时清理
java·数据库·设计模式·rocketmq
lifallen7 小时前
Paimon LSM Tree Compaction 策略
java·大数据·数据结构·数据库·算法·lsm-tree
{⌐■_■}11 小时前
【Kafka】登录日志处理的三次阶梯式优化实践:从同步写入到Kafka多分区批处理
数据库·分布式·mysql·kafka·go
isNotNullX11 小时前
数据中台架构解析:湖仓一体的实战设计
java·大数据·数据库·架构·spark
睿思达DBA_WGX14 小时前
由 DB_FILES 参数导致的 dg 服务器无法同步问题
运维·数据库·oracle
袋鼠云数栈15 小时前
使用自然语言体验对话式MySQL数据库运维
大数据·运维·数据库·后端·mysql·ai·数据治理·数栈·data+ai