SQLServer将查询内容拼接成字符串输出(超全⾯!)
⼀、背景
当我想通过 select 语句将查询内容拼接成字符串输出时出现这种情况。
select U_ID+U_NAME from MES_USER
消息 245,级别 16,状态 1,第 1 ⾏
在将 varchar 值 '⼩⽩' 转换成数据类型 int 时失败。
⽤+号直接拼接的肯定不⾏,那是在编程语⾔中的做法。
⼆、问题解决
(1)问题重现
select 1+'--Test--'
--> 在将 varchar 值 '--Test--' 转换成数据类型 int 时失败。
(2)解决⽅案
⽅案⼀:cast 函数
select CAST(1 as varchar)+ '--Test--'
--> '1--Test--'
⽅案⼆:convert 函数
在 sql 语句中⽤ cast 或 convert 函数进⾏强转,转型成功后即可拼接
select CONVERT(varchar,1)+ '--Test--'
--> '1--Test--'
⽅案三:RTRIM()/ LTRIM()字符串函数
select RTRIM(U_ID)+U_NAME from MES_USER
select LTRIM(U_ID)+U_NAME from MES_USER
这⾥使⽤了SQL SERVER字符串函数LTRIM() / RTRIM(),分别为去除字符串左边多余的空格函数和去除字符串右边多余的空格函数,此为⼀对函数。在去掉空格时会将其中类型强转成字符串类型。
⽅案四:(重点来了!)
select (STUFF((select ','+ RTRIM(U_ID) + U_NAME from MES_USER for xml path ('')),1,1,''))
这个 sql 是将所有查询内容拼接成⼀整串字符串,并⽤逗号隔开,稍微复杂了⼀点点,涉及到三个函数,不过不急,待我慢慢道来……
函数⼀:字符串函数LTRIM()/RTRIM()
这个上⾯说过了,不再复述。
函数⼆:for xml path(param)--将查询结果以xml格式输出
(1)当 path 后⾯没有参数时,每⾏数据被默认 <row> 标签包裹,每⾏列数据被被其列名标签包裹。例:
select U_ID,U_NAME from MES_USER for xml path
-
-结果:
<row>
<U_ID>1</U_ID>字符串replace函数
<U_NAME>⼩⽩</U_NAME>
</row>
<row>
<U_ID>2</U_ID>
<U_NAME>⼩⿊</U_NAME>
</row>
<row>
<U_ID>3</U_ID>
<U_NAME>⼤⿊</U_NAME>
</row>
(2) - 每⾏数据最外⾯包裹的标签由path的参数控制(没有参数时,默认为row),所以要去掉则可以直接给⼀个空字符串作为path的参数。
- 每⾏列数据所被直接包裹的标签由查询结果的列名控制,要去掉只需要保证查询出来的列没有列名就可以了(保证没有列名最简单的⽅法是给每个字段加⼀个空字符串)。例:
select U_ID+'',U_NAME+'' from MES_USER for xml path('')
--结果
1⼩⽩2⼩⿊3⼤⿊
函数三:stuff函数
格式:stuff(character_expression, start, length, replaceWith_expression)
删除原字符串(character_expression)指定起始位置(start)指定长度(length)的字符,并在该位
置插⼊代替的字符
(replaceWith_expression)
select (STUFF((select ','+ RTRIM(U_ID) + U_NAME from MES_USER for xml path ('')),1,1,''))
这⾥的意思就是将第⼀个逗号⽤空字符替换掉。
⼩提⽰:这⾥查出来的结果可以放到另⼀个 select 的条件 IN ⾥⾯,特别⽅便,练熟之后就不⽤⽼是⼀个个去添加逗号了。
三、补充
将⼩数返回成百分数的格式输出。
(1)不保留⼩数位
select cast(cast(0.888876*100 as numeric(3,0)) as varchar(10)) +'%' --> 89%
(2)保留⼩数位
select cast(cast(0.888876*100 as numeric(5,2)) as varchar(10)) +'%' --> 88.89%
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论