• 数据库update(动态更新)-SqlServer


    最近项目上经常需要去通过SQL脚本去刷数据库历史数据的情况

    --第一种:简单更新的SQL语句
    update 表名 set 字段 = 更新值 where 条件
    --第一种方式简单,但是个别复杂的情况难以直接更新
    
    
    --第二种:复杂的通过脚本写逻辑
    DECLARE 
    @ID VARCHAR(10),
    @TEXT VARCHAR(7999),
    @JMTX VARCHAR(7999)
    DECLARE My_Cursor CURSOR --定义游标
    FOR (select xx字段 from xxx表 where 条件) --查出需要的数据放到游标中
    OPEN My_Cursor; --打开游标
    FETCH NEXT FROM My_Cursor into @ID; --读取第一行数据
    WHILE @@FETCH_STATUS = 0
        BEGIN
            --遍历ID查询单条数据
    		set @TEXT=(select xx字段1 from xxx表1 where xx字段2 = @ID);
    		if(@TEXT IS null)
    		begin
    		--更新语句
    		update 表名 set 字段 = 更新值 where 条件
    		end
    END
    CLOSE My_Cursor; --关闭游标
    DEALLOCATE My_Cursor; --释放游标
    --第二种方式的话稍微比较麻烦
    
    
    --第三种:简易更新语句升级版(在需要更新值的值查出来放到同一行数据中以便获取)
    update t1 set t1.zbbm1 = t2.cbbm 
    from xx表1 t1 
    inner join (select requestid,cbbm from xx表2) t2 on t1.lcid = t2.requestid
    where (t1.zbbm1 is null or LTrim(RTrim(t1.zbbm1)) = '')
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34

    还有什么更好的SQL脚本写法也可以分享一下啦

  • 相关阅读:
    11.21序列检测,状态机比较与代码,按键消抖原理
    Vim快捷用法
    8月4日第壹简报,星期四,农历七月初七,七夕节
    FFmpeg源码编译
    Microsoft Excel 101 简介
    Github Actions 自动同步到 Gitee
    haproxy 负载均衡
    【Netty 的设计与应用】
    C语言-结构体(7)
    面试-Redis-缓存击穿
  • 原文地址:https://blog.csdn.net/weixin_43316702/article/details/127650314