程序问答   发布时间:2022-06-02  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了使用 cte 交换表的两列大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决使用 cte 交换表的两列?

开发过程中遇到使用 cte 交换表的两列的问题如何解决?下面主要结合日常开发的经验,给出你关于使用 cte 交换表的两列的解决方法建议,希望对你解决使用 cte 交换表的两列有所启发或帮助;

我想使用 CTE 交换一张表的第 2 列和第 3 列。 我正在使用以下查询,它不断抛出错误, 没有这样的列:cte.comm1 表 - [SalComm] 列:ID、Sal、Comm

with CTE as 
    (
      SELECT ID as ID1,sal as sal1,comm as comm1 from SalComm
    ) updatE SalComm SET sal=cte.comm1,comm=cte.sal1 where ID= cte.ID1*

你能给我建议正确的查询吗?

解决方法

这个答案假设您使用的是 SQL Server 或其他一些支持直接更新公用表表达式的数据库。我没有看到您 CTE 中的所有别名的重点。如果要交换列值,只需使用直接列名:

WITH cte AS (
    SELECT ID,sal,comm
    FROM SalComm
)

updatE cte
SET sal = comm,comm = sal;
-- no WHERE clause needed,if you really want to cover the entire table

如此,您可以同样轻松地对原始表进行上述更新。可更新的 CTE 在生成一些复杂的派生结果时更有用,您打算将这些结果用作以后更新的一部分。此处似乎并非如此。

大佬总结

以上是大佬教程为你收集整理的使用 cte 交换表的两列全部内容,希望文章能够帮你解决使用 cte 交换表的两列所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。