SQL 函数返回字符串中的最大值最小值(XML新解法)

功能 参数

指定的分隔符 分隔值 集合 (如 123,12,55,2222,90

函数返回

集合中的最大值,最小在收集和集合中的值的数目


/*

 例:

运行下面的函数

select* from dbo.GetMaxandMinValue('2,22,5,1,88,2000,7897,800',',')

 得到这样的结果

minValue  maxValue  CountOfNumberSupplied

-------------------------------------------------------------------

1.00   7897.00   8

 

*/

if object_id('GetMaxandMinValue','F')is not null drop functionGetMaxandMinValue

go

createfunctionGetMaxandMinValue(@valuescollection varchar(max),@separatorchar(1))

returns@table table(minvalue numeric(20,2),maxvaluenumeric(20,2),countofnumbersuppliedint)

as

begin

    declare@x xml

    declare@minnumber varchar(50)

    declare@maxnumber varchar(50)

    declare@numbercount varchar(20)

    select@x='<number>'+ replace(@valuescollection,@separator,'</number><number>')+'</number>'

    select@minnumber= convert(varchar(50),@x.query('fn:min(number)'))

    select@maxnumber= convert(varchar(50),@x.query('fn:max(number)'))

    select@numbercount= convert(varchar(50),@x.query('fn:count(number)'))

    insertinto @table select cast(@minnumberas float),cast(@maxnumberas float),cast(@numbercountas int)

    return;

end

go

select* from dbo.GetMaxandMinValue('2,22,5,1,88,2000,7897,800',',')

 


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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值