免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4138 | 回复: 4
打印 上一主题 下一主题

关于select @a=@b,@b=@a [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-06-04 10:05 |只看该作者 |倒序浏览
为什么我得到的结果不是ab互换呢?

论坛徽章:
0
2 [报告]
发表于 2008-06-04 10:52 |只看该作者
原帖由 yan32768 于 2008-6-4 10:05 发表
为什么我得到的结果不是ab互换呢?


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

论坛徽章:
0
3 [报告]
发表于 2008-06-04 11:50 |只看该作者
我认为ab应该互换值,而不应该顺序执行赋值,因为我执行的是“一条”sql语句,在语句未执行完前,ab的值不应该是变化的。

论坛徽章:
0
4 [报告]
发表于 2008-10-13 15:08 |只看该作者

select a=b,b=a from table1

上述功能能够实现ab互换

论坛徽章:
0
5 [报告]
发表于 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
表结构就不开了,否则又臭又长了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP