关闭

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

标签: xmlsqlobjecttablenull
2146人阅读 评论(0) 收藏 举报
功能参数

指定的分隔符分隔值集合(如 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

猜你在找
【套餐】Hadoop生态系统零基础入门
【套餐】嵌入式Linux C编程基础
【套餐】2017软考系统集成项目——任铄
【套餐】Android 5.x顶级视频课程——李宁
【套餐】深度学习入门视频课程——唐宇迪
【直播】广义线性模型及其应用——李科
【直播】从0到1 区块链的概念到实践
【直播】计算机视觉原理及实战——屈教授
【直播】机器学习之凸优化——马博士
【直播】机器学习&数据挖掘7周实训--韦玮
查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:146927次
    • 积分:2060
    • 等级:
    • 排名:第18537名
    • 原创:37篇
    • 转载:12篇
    • 译文:0篇
    • 评论:107条
    最新评论