在项目开发过程中存储过程会用到很多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 ] )