SQL Server 中带有 while 循环的用户定义函数
Posted
技术标签:
【中文标题】SQL Server 中带有 while 循环的用户定义函数【英文标题】:User defined function with while loop in SQL Server 【发布时间】:2020-04-09 16:22:55 【问题描述】:我被要求在 SQL Server 中创建一个用户定义的函数以返回以下模式(例如,如果输入 = 5):
*****
****
***
**
*
这是我的代码:
alter function udf_star (@input int)
returns varchar (200)
as
begin
declare @star int
set @star = @input
declare @space int
set @space = 0
while @star > 0
begin
declare @string varchar (200)
set @string = replicate (' ', @space) + replicate ('*', @star)
set @star = @star - 1
set @space = @space + 1
end
return @string
end
当我执行函数时
select dbo.udf_star (5)
它只显示
' *'
(4 个空格 + 1 颗星);谁能指出我应该如何更正语法?
提前致谢!
【问题讨论】:
。 .(1) 使用我在您之前的回答中建议的递归 CTE; (2) 你似乎想返回一个表,而不是一个标量值。 感谢@GordonLinoff,是的,CTE 是一个很好的解决方案,但我正在尝试不同的 SQL 工具,想知道如何通过 UDF 实现这一目标。 【参考方案1】:看来您可能需要一个表值函数。
此外,应尽可能避免循环
示例
CREATE FUNCTION [dbo].[tvf-Star] (@Input int)
Returns Table
As
Return (
Select Top (@Input)
Stars = replicate(' ',@Input-N)+replicate('*',N)
From ( Select Top (@Input) N=Row_Number() Over (Order By (Select NULL)) From master..spt_values n1 ) A
Order By N Desc
)
如果你:
Select * from [dbo].[tvf-Star](5)
结果
Stars
*****
****
***
**
*
【讨论】:
以上是关于SQL Server 中带有 while 循环的用户定义函数的主要内容,如果未能解决你的问题,请参考以下文章
如何删除 MS SQL Server 存储过程中的 While 循环? [关闭]