zoukankan      html  css  js  c++  java
  • SQL函数经常用到的mark一下

    在项目开发过程中存储过程会用到很多SQL函数,经常用到的mark一下

    1、经常用到的
    mark 一下

    经常需要把id字符以','分隔传入存储过程
    然后SQL语句用in去搜索
    但是经常是这样的情况
    id 经常是int bigint类型,传进来的经常是的字符串类型
    所以经常需要用到SQL字符串拼接

    eg :
    1、不需要返回值的
    set @STRSQL='SELECT * FROM TABLE WHERE ID IN('+@TestContent+')'
    EXEC @STRSQL

    2、需要返回值
    set @STRSQL=N'SELECT @TestContent=(SELECT STUFF((SELECT ''/''+Title FROM TestItem WHERE ID
    IN('+ @TestContent +')AND DeFLAGS=0 FOR XML PATH('''')),1,1,''''))'

    EXEC sp_executesql @STRSQL,N'@TestContent NVARCHAR(4000) output',@TestContent output


    STUFF函数
    STUFF 函数将字符串插入到另一个字符串中。 它从第一个字符串的开始位置删除指定长度的字符;然后将第二个字符串插入到第一个字符串的开始位置。

    语法:
    STUFF ( character_expression , start , length , replaceWith_expression )

    SELECT STUFF('abcdef',2,2,'hijklmn') 结果是 “ahijklmndef”,主意下标从1开始算起

    FOR XML PATH 用法:用于将查询结果集以XML形式展示

    SELECT * FROM TABLE FOR XML PATH

    SELECT ID AS test,Code AS TESTCode FROM Bills FOR XML PATH('abc')

    按照自己的格式输出显示

    SELECT '/'+PATH FROM TABLE FOX XML PATH('')


    sp_executesql 用法

    sp_executesql [ @stmt = ] statement
    [
    { , [ @params = ] N'@parameter_name data_type [ OUT | OUTPUT ][ ,...n ]' }
    { , [ @param1 = ] 'value1' [ ,...n ] }--用来接收输出值的参数,必须是已定义好的参数
    ]

    可以有带输入、输出值

    eg:
    EXEC sp_executesql @STRSQL,N'@TestContent NVARCHAR(4000) output',@TestContent output

    DATEDIFF 用法:

    DATEDIFF ( datepart , startdate , enddate )

    DATEDIFF(DAY,'2014-10-10',GETDATE())

    分页:

    ROW_NUMBER() 函数

    SELECT ROW_NUMBER() OVER (order by id),* FROM TABLE

    类型转换

    CAST 、CONVETR 函数:

    CAST ( expression AS data_type [ ( length ) ] )

    CONVERT ( data_type [ ( length ) ] , expression [ , style ] )
  • 相关阅读:
    软件测试流程
    Python2 RF(3.0.4)与Python3 RF(3.1.2)区别
    Ubuntu Install RobotFramework with Python3
    Beta测试与Alpha测试有什么区别
    网络协议,如TCP/UDP的区别?
    缺陷相关知识
    linux_machine-id
    monkey自定义脚本实践
    Monkey事件
    Linux虚拟机fdisk分区
  • 原文地址:https://www.cnblogs.com/yudeyinji/p/4027185.html
Copyright © 2011-2022 走看看