没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
原创|其它|编辑:郝浩|2009-06-09 14:01:22.000|阅读 633 次
概述:本文是为那些刚刚在SQL开发领域开始他们职业生涯的新手而写的。当他们把数据导入或者插入表中时,他们都可能遇到这样的问题,那就是不小心把数据放在错误的列中。我们首先想到的是删除数据然后重新插入数据,但是在这个技巧中我们将通过一个简单的方法来交换数据。
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
本文是为那些刚刚在SQL开发领域开始他们职业生涯的新手而写的。当他们把数据导入或者插入表中时,他们都可能遇到这样的问题,那就是不小心把数据放在错误的列中。我们首先想到的是删除数据然后重新插入数据,但是在这个技巧中我们将通过一个简单的方法来交换数据。
专家解答
为了描述这个问题,我将创建一个简单的表,并且插入两个带有如下显示的相同数据类型的列。
CREATE TABLE SwapData(id int,value1 varchar(50),value2 varchar(50))
GO
现在这个表已经创建了,接下来我们在这个表中插入一些值。在这里,我使用一个UNION ALL语句,因此我就可以做一次INSERT,但是这也可以通过执行几个插入语句来完成。
INSERT INTO Swapdata
SELECT 1,10,100
UNION ALL
SELECT 2,20,200
UNION ALL
SELECT 3,30,300
UNION ALL
SELECT 4,40,400
UNION ALL
SELECT 5,50,500
UNION ALL
SELECT 6,60,600
UNION ALL
SELECT 7,70,700
UNION ALL
SELECT 8,80,800
UNION ALL
SELECT 9,90,900
UNION ALL
SELECT 10,11,110
正如下面的图像所示,这将在“value1”和“value2”中插入具有不同值的十行。
图一
现在数据已经插入,我们可以看到较大的值应该在"value1"。因此现在我们需要交换“value1” 和“value2”中的值。
这里有很多种方法来解决这个问题。正如在问题部分所讨论的,你可以删除这些数据然后再重新插入,或者你可以创建一个新的列然后把这些数据移过去,但是这里还有更简单的方法。
其中一个间的方法显示如下,那就是创建一个临时的变量,这个变量允许你更新数据和交换列值。
DECLARE @temp AS varchar(50)
UPDATE swapdata SET @temp=value2,value2=value1,value1=@temp
我们不是在这个表中创建一个临时列,而是通过声明一个临时变量来交换这两个列中的数据。上面的代码解释如下:
首先创建一个临时变量。
然后把列"value2"的数据放在@temp变量中。
接着把列"value1"的数据放在"value2"列中。
最后把@temp的值放在"value1"列中。
现在,我们来查询这个表的行。
SELECT * FROM swapdata
我们可以看到我们的表已经正确更新了。
图二
但是我发现最好的解决方法是不用任何临时变量。
只需执行下面的T-SQL,它将交换列数据。
UPDATE swapdata SET value2=value1,value1=value2
它把数据从value1迁移到value 2,同时也把value2的数据迁移到value 1。
现在,我们来查询这个表。我们可以看到数据已经交换回原来的位置。
SELECT * FROM swapdata
图三
我尝试相同的砝码来解决三个列的问题。
让我们在“swapdata”表中再添加第三个列“value3”。
ALTER TABLE swapdata ADD value3 varchar(50)
GO
UPDATE swapdata SET value3=value2+'0'
SELECT * FROM swapdata
图四
让我们如下交换这些列的值:
· "value1"获得"value3"的数据
· "value2"获得"value1"的数据
· "value3"获得"value2"的数据
我们将按照第二种解决方法来获得这个结果。
UPDATE swapdata SET value1=value3,value2=value1,value3=value2
SELECT * FROM swapdata
图五
注意,交换列的系列可以按照任何顺序来给定。只要确保这个值在每个请求输出结果中传递即可。我认为这些方法对于每个人都很有用,只要交换列值,无需为临时列和变量而烦恼。
因此下次你再遇到在一张表的多个列中交换数据,只需记住这个简单的方法。
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com
文章转载自:IT专家网接DevExpress原厂商通知,将于近日上调旗下产品授权价格,现在下单客户可享受优惠报价!
面对“数字中国”建设和中国制造2025战略实施的机遇期,中车信息公司紧跟时代的步伐,以“集约化、专业化、标准化、精益化、一体化、平台化”为工作目标,大力推进信息服务、工业软件等核心产品及业务的发展。在慧都3D解决方案的实施下,清软英泰建成了多模型来源的综合轻量化显示平台、实现文件不失真的百倍压缩比、针对模型中的大模型文件,在展示平台上进行流畅展示,提升工作效率,优化了使用体验。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@evget.com
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
慧都科技 版权所有 Copyright 2003-
2025 渝ICP备12000582号-13 渝公网安备
50010702500608号