sql - SQL Server 中带有 while 循环的用户定义函数
问题描述
我被要求在 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 颗星);谁能指出我应该如何更正语法?
提前致谢!
解决方案
看来您可能需要一个表值函数。
此外,应尽可能避免循环
例子
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
*****
****
***
**
*
推荐阅读
- python - Python SymPy 块矩阵类型错误
- vb.net - VB.Net在一个类的一个实例中更改属性的值,在另一个实例中更改它
- java - Java 8 Streams:计算元素的出现次数(列表
list1) 来自文本数据列表(List 清单2) - java - 如何从 Java 文件中解析 json 对象列表?
- visual-studio -
未包含在 Visual Studio 2017 中 MailAppVersionOverridesV1_1 的架构定义中? - ruby-on-rails - 将我的域从 www 更改为非 www,现在不再创建我的 cookie
- pandas - 考拉数据框列操作
- php - 使用 php 脚本运行时,带有 where 子句的 oracle 选择查询返回不完整的记录
- python-tesseract - PyTesseract - 安装问题
- xcode - Xcode 11.3.1 未在调试器中显示 NSObject 子类成员