是否有一种方法可以更新SQL server中的多个列,以插入语句的相同方式使用?

喜欢的东西:

Update table1 set (a,b,c,d,e,f,g,h,i,j,k)=
(t2.a,t2.b,t2.c,t2.d,t2.e,t2.f,t2.g,t2.h,t2.i,t2.j,t2.k)
from table2 t2
where table1.id=table2.id

或者类似的东西,而不是像这样:

update table set a=t2.a,b=t2.b etc 

如果你有100多个列,写起来会很累人。


当前回答

“令人厌烦的方式”是标准SQL和主流RDBMS如何做到这一点。

对于100多个列,您很可能遇到了设计问题……此外,在客户端工具中(例如生成UPDATE语句)或使用orm也有缓解方法

其他回答

   UPDATE t1 
    SET 
    t1.a = t2.a,
    t1.b = t2.b,
    .
    .
    .


    FROM 
    table1 t1 
    INNER JOIN table2 t2 ON  t1.id=t2.id

你可以试试这个

“令人厌烦的方式”是标准SQL和主流RDBMS如何做到这一点。

对于100多个列,您很可能遇到了设计问题……此外,在客户端工具中(例如生成UPDATE语句)或使用orm也有缓解方法

试试这个:

UPDATE table1 
SET a = t2.a, b = t2.b, .......
FROM table2 t2
WHERE table1.id = t2.id

这应该适用于大多数SQL方言,不包括Oracle。

是的,这需要大量的输入,这就是SQL的方式。

如果你需要多次重新输入,你可以像我这样做一次。 将列的名称放入excel表格中的行中(在每个列名的末尾写下(=),这在notepad++中很容易),在右侧制作一个列来复制和粘贴您的值,这将对应于每列的新条目。然后在它们的右边一个独立的栏中按设计的那样加上逗号

然后你将不得不复制你的值到中间列每次,然后只是粘贴然后运行

我不知道还有什么更简单的解决办法

语法

UPDATE table-name 
SET column-name = value, column-name = value, ...
WHERE condition

例子

UPDATE school
SET course = 'mysqli', teacher = 'Tanzania', student = 'you'
WHERE id = 6