gpt4 book ai didi

sql-server-2005 - 更新表而不命名所有列

转载 作者:行者123 更新时间:2023-12-04 07:25:43 24 4
gpt4 key购买 nike

我找到了一种使用此模板使来自不同数据库的两个表相互匹配的方法:

INSERT [DestDB].[dbo].[TABLE]
SELECT source.* FROM
[SourceDB].[dbo].[TABLE] AS source
LEFT OUTER JOIN
[DestDB].[dbo].[TABLE] AS dest
ON
source.[PKColumn] = dest.[PKColumn]
WHERE dest.[PKcolumn] IS NULL

UPDATE dest
SET
dest.[PK_COLUMN1] = source.[PK_COLUMN1]
,dest.[COLUMN2] = source.[COLUMN2]
,dest.[COLUMN3] = source.[COLUMN3]
,dest.[COLUMN4] = source.[COLUMN4]
,dest.[COLUMN5] = source.[COLUMN5]
,dest.[COLUMN6] = source.[COLUMN6]
,dest.[COLUMN7] = source.[COLUMN7]
,dest.[COLUMN8] = source.[COLUMN8]

FROM
[SourceDB].[dbo].[TABLE] AS source
INNER JOIN
[DestDB].[dbo].[TABLE] AS dest
ON source.[PK_Column1] = dest.[PK_Column1]

然而,我正在使用的一些表至少有 200 列,虽然可以通过复制 + 粘贴的功能来做到这一点,但我只需要知道是否有一种方法不会让我患上心皮隧道综合症。

我正在使用 Microsoft SQL Server 2005。

有什么建议吗?

最佳答案

我认为您不能在不命名列的情况下更新列,但是您可以使用 SQL 和 sys.columns View 为您编写脚本:

select ',dest.[' + name + '] = source.[' + name +']' 
from sys.columns
WHERE object_id = OBJECT_ID(N'[dbo].[Widgets]')

- 输出 -
,dest.[WidgetId] = source.[WidgetId]
,dest.[WidgetName] = source.[WidgetName]
,dest.[CreatedDt] = source.[CreatedDt]
,dest.[WidgetValue] = source.[WidgetValue]
,dest.[ModifiedDt] = source.[ModifiedDt]

唯一的另一种方法是不更新,而是截断 dest 表并执行 SELECT INTO
SELECT * INTO DEST FROM SOURCE

关于sql-server-2005 - 更新表而不命名所有列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12144516/

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