大佬教程收集整理的这篇文章主要介绍了使用 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,请注明来意。