从我的理解是: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(,
@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
表结构就不开了,否则又臭又长了。