- 论坛徽章:
- 0
|
回复 #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
表结构就不开了,否则又臭又长了。 |
|