本文主要是介绍SQL Server之STUFF 使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
例子1、
DECLARE @Time VARCHAR(10)
SET @Time = ‘1030’
SELECT STUFF(@Time, 3, 0, ‘:’) AS [HH:MM]
输出:10:30
我们给定的字符串为@Time即1030,我们从第3个位置开始,删除长度为0,此时则在3前面插入冒号,结果如上图输出10:30。
例子2、
DECLARE @CreditCardNumber VARCHAR(20)
SET @CreditCardNumber = ‘370200199408103544’
SELECT STUFF(@CreditCardNumber, LEN(@CreditCardNumber) -3, 4,
‘XXXX’) AS [Output]
输出:37020019940810XXXX
如上我们将身份证通过STUFF将最后四位用XXXX代替。以上是STUFF最基础的用法。
STUFF最常见的用途莫过于结合FOR XML PATH对返回JSON字符串的拼接。首先利用FOR XML PATH则返回XML格式的字符串,我们将FOR XML PATH添加到查询的末尾,此时允许我们将查询的结果作为XML元素输出,元素名称包含在PATH参数中。。
SELECT TOP 5 ‘,’ + Name
FROM Production.Product
FOR XML PATH (”)
输出:,Adjustable Race,All-Purpose Bike Stand,AWC Logo Cap,BB Ball Bearing,Bearing Ball
此时我们利用STUFF将上述利用FOR XML PATH生成的字符串中的前置逗号去掉,如下:
SELECT Name = STUFF((
SELECT TOP 5 ‘,’ + NAME
FROM Production.Product
FOR XML PATH(”)
), 1, 1, ”)
输出:Adjustable Race,All-Purpose Bike Stand,AWC Logo Cap,BB Ball Bearing,Bearing Ball
这篇关于SQL Server之STUFF 使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!