网站建设资讯

NEWS

网站建设资讯

sqlserver表函数,sqlserver函数返回表

sqlserver 函数的写法

returns @RowSet table(

网站设计制作过程拒绝使用模板建站;使用PHP+MYSQL原生开发可交付网站源代码;符合网站优化排名的后台管理系统;网站建设、做网站收费合理;免费进行网站备案等企业网站建设一条龙服务.我们是一家持续稳定运营了十载的成都创新互联公司网站建设公司。

ID int identity(1,1) ,

score float,

lastScore float

)

你这里已经声明了一个表格类型变量作为函数的返回值.

那么只要在函数里对这个表进行赋值,就可以直接return

insert into @RowSet values(...)

return

--------

declare @ScoreList table (YScore float)

declare @ScoreList1 table (lastScore float)

-------------------------------------------

怎么我看你又声明了两个表格类型的变量?你函数声明里的返回类型是表,那么单行返回的话就只能往里装简单类型的值.

如果你要union拼接两个table一起返回的话,两个内部table和声明的返回table定义又不一致.

很奇怪的写法...能看出来你想干什么...但这种写法很怪异.

========================================补充

insert into @ScoreList SELECT...

insert into @ScoreList1 SELECT ...

你这不是把两个查询的结果赋给两个内部变量了么,且这个表与你声明的返回表都是一个float列.

你完全可以再把这两个变量表insert 到@RowSet啊,或者不用这俩变量表,直接在两个查询里向@RowSet写入值.

最后直接

return

end

不就行了?

======

这有个返回值为talble的函数,你参看一下吧.你这个函数的完成度已经相当高了.

SqlServer函数的系统函数

newid 无参数

返回一个GUID(全局唯一表示符)值

例如:select newid()

返回:2E6861EF-F4DB-4FFE-86EB-637482FE982J2

isnumeric (任意表达式)

判断表达式是否为数值类型或者是否可以转换成数值。

是:返回1,不是:返回0

例如:select isnumeric(1111) 返回 1

select isnumeric('123rr') 返回 0

select isnumeric('123') 返回 1

isnull (任意表达式1,任意表达式2)

如果任意表达式1不为NULL,则返回它的值;否则,在将任意表达式2的类型转换为任意表达式1的类型(如果这两个类型不同)后,返回任意表达式2的值。

例如:select isnull(null,N'没有值') 返回 没有值

select isnull(N'具体的值',N'没有值') 返回 具体的值

isdate (任意表达式)

确定输入表达式是否为有效日期或可转成有效的日期;

是:返回1,不是:返回0

例如:select isdate(getdate()) 返回1

select isdate('2013-01-02') 返回1

select isdate('198') 返回0

SqlServer函数

创建自定义函数:

use 数据库名

go

create function 函数名

(@pno int)

returns int

as

begin

declare @a int

if not exists(select * from person where pno=@pno)

set @a=-1

else

set @a=1

return @a

end

调用函数:

use 数据库名

go

select dbo.函数名(13250)


文章名称:sqlserver表函数,sqlserver函数返回表
转载注明:http://cdweb.net/article/hoijch.html