yan32768 发表于 2008-06-04 10:05

关于select @a=@b,@b=@a

为什么我得到的结果不是ab互换呢?

admin8776 发表于 2008-06-04 10:52

原帖由 yan32768 于 2008-6-4 10:05 发表 http://bbs.chinaunix.net/images/common/back.gif
为什么我得到的结果不是ab互换呢?

从我的理解是:a,b是一样的啊,不会互换,不知各位大侠有啥看法

yan32768 发表于 2008-06-04 11:50

我认为ab应该互换值,而不应该顺序执行赋值,因为我执行的是“一条”sql语句,在语句未执行完前,ab的值不应该是变化的。

yan32768 发表于 2008-10-13 15:08

select a=b,b=a from table1

上述功能能够实现ab互换

kanfu 发表于 2008-10-13 15:54

回复 #1 yan32768 的帖子

这个问题我以前研究过,SQL server和sybase都一样,可能内部用指针实现的吧。
但如果右边是字段列两者表现就不一样,只能解释为SQLServer按顺序赋值,Sybase是变量对变量先赋值:)
如下SQL:
create table test001(c1 varchar(20) , c2 varchar(20))
go
insert into test001 values('1','a12')
go
declare
@ia varchar(20), @ib varchar(20)
begin
select @ia = '1', @ib = '2'
select @ia,@ib
select @ia = c2, @ib=@ia from test001
select @ia,@ib
end
go
在sybase 下最后的结果是a12, 1
在SQL server 下的结果是a12,a12

这个特性在要统计表中每行的累计值得时候很有用,如ABC计算。
declare
@s_FamilyCode varchar(8),
@d_TotSaleQty decimal(14,3)
begin
select @s_FamilyCode = '',@d_TotSaleQty = 0
update ItemSale set TotSaleQty = 0
update ItemSale
set TotSaleQty = case when FamilyCode = @s_FamilyCode then SaleQty @d_TotSaleQty else SaleQty end ,
      @d_TotSaleQty = case when FamilyCode = @s_FamilyCode then @d_TotSaleQty SaleQty else SaleQty end,
      @s_FamilyCode = FamilyCode
end
go
表结构就不开了,否则又臭又长了。
页: [1]
查看完整版本: 关于select @a=@b,@b=@a