gpt4 book ai didi

sql-server - 条件更新语句 T-SQL

转载 作者:行者123 更新时间:2023-12-02 00:55:31 25 4
gpt4 key购买 nike

我正在尝试用 SQL 更新一个非常宽的表,该表多年来误用了一些列,导致了一些非常困惑的数据。我想编写一个条件更新语句来将数据从一列转移到另一列,因为如果它们不为空,它们基本上都偏离它们应该在的位置的一列。

UPDATE SOME_TABLE
SET Data1 = (CASE WHEN Data1 IS NOT NULL THEN Data1 = Data0 ELSE Data1),
SET Data2 = (CASE WHEN Data2 IS NOT NULL then Data2 = Data1 ELSE Data2),
SET Data3 = (CASE WHEN Data3 IS NOT NULL then Data3 = Data2 ELSE Data3)
GO

我怎样才能构造这个以有条件地“转移”数据,就像我想做的那样?

示例 - Data0 始终为 NULL(从未正确使用)

所以数据总是这样:NULL ||字母表 ||新鸿运 || XYZ

在这种情况下,我需要将每一列在给定行中向左移动一列。里面的数据都是VARCHAR。

最佳答案

So I need Data 1 to move to Data 0 when not null. Seems like I am missing something

您需要使用 data1 的值更新 data0,而不是相反:

UPDATE SOME_TABLE
SET Data0 = CASE WHEN Data1 IS NOT NULL THEN Data0 ELSE Data0 END,
Data1 = CASE WHEN Data2 IS NOT NULL then Data1 ELSE Data1 END,
Data2 = CASE WHEN Data3 IS NOT NULL then Data2 ELSE Data2 END;

从您的描述来看,似乎根本不需要这种情况。显然,如果 data0 为空,您想移动所有列:

UPDATE SOME_TABLE
SET Data0 = Data1,
Data1 = Data2,
Data2 = Data3
WHERE data0 IS NULL; -- only shift if data0 is "empty"

关于sql-server - 条件更新语句 T-SQL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35825335/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com