Chinaunix

标题: 关于select @a=@b,@b=@a [打印本页]

作者: yan32768    时间: 2008-06-04 10:05
标题: 关于select @a=@b,@b=@a
为什么我得到的结果不是ab互换呢?
作者: admin8776    时间: 2008-06-04 10:52
原帖由 yan32768 于 2008-6-4 10:05 发表
为什么我得到的结果不是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(,
  @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
表结构就不开了,否则又臭又长了。




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2