T-sql 学习(3) - compute和Xp_**族函数

1,T-sql性能

Halloween问题:由于存储结构(B+树)造成对数据的循环,甚至是死循环,操作;
因为这个事件发生在万圣节前一天,所以得名;

 

2,日期时间:
DateDiff是一个好东西,计算两个时间的差异:尤其对于闰年等特殊情况非常有效

 

3,compute by,功能
1) 使用Compute by子句和行统计函数(count,sum,max,avg,min等),可以统计排序中结果完全相同的列,统计值作为查询结果以附加行的形式显示,MS推荐使用Group by的rollup来替代这个功能 

 

2) 细节:
GROUPING ( column_name )
参数column_name,是GROUP BY 子句中的列,用于测试该column是不是出于 CUBE 或 ROLLUP 的统计行,也就是说,是不是一个统计行造成的空值。
grouping结果的意义:如果这一行是rollup或者cube的结果,那么这个值为1;否则0;

rollup的功能是,在结果集中增加一行,对分行统计的结果进行总计;

 

细节可以参考:http://www.cnblogs.com/music000/archive/2008/01/29/1057898.html

 

4,xp_sprintf,xp_**一族函数,是有外部DLL进行的SqlServer扩展,不是标准的sp。
而且,比如,xp_sendmail,在后续版本的 Microsoft SQL Server 将删除该功能。
所以(我)并不建议使用这类函数;但是他们确实能丰富一些功能。

 

举例:
declare @result varchar(80), @v1 varchar(80), @v2 varchar(80)
set @v1 = 'zhang'
set @v2 = 'wang'

-- 目前仅支持 %s 格式参数,XP_sscanf也是一样
exec xp_sprintf @result output, '%s and %s', @v1, @v2

print @result

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值