职业IT人-IT人生活圈

 找回密码
 成为会员
搜索
查看: 912|回复: 0

创建自定义用户函数实例

[复制链接]
要狠 发表于 2009-4-28 20:04 | 显示全部楼层 |阅读模式
create function GetTotal(@stuNo nvarchar(20))--创建自定义函数(带参数)
returns int                                  --表示本函数的返回值类型为int,注意returns必须加s
as
begin
        declare @sum int                         --定义变量@sum
        select @sum=writtenExam+LabExam from dbo.stuMarks
        where stuNo=@stuNo                       --给变量@sum赋值,表示总分
        return @sum                              --此处return无需加s
end

select dbo.GetTotal(\'s25303\')                --
--\'GetTotal\' 不是可以识别的内置函数名称。

alter function gettable(@tables nvarchar(20))
returns nvarchar(20)
begin
     declare @cou int,@newtables nvarchar(20)
     set @newtables = @tables
     select @cou = count(*) from @newtables
     return @cou
end
  

alter function GetNewCID(@cid varchar(32))--0000
returns varchar(32)
as
begin
        declare @newid varchar(32),@temp int

        --判断该节点@cid下面是否包含子节点
        if not exists (select * from tb_Category where ParentId = @cid)
                return @cid + \'00\'

        --取出以@cid为父节点的节点里面最大的节点id
        select @newid=max(CategoryId) from dbo.tb_Category
                where ParentId = @cid;--000003
        set @newid=right(@newid,2)

        set @temp=convert(int,@newid)+1
        set @newid = \'0\' + ltrim(str(@temp))
        set @newid = right(@newid,2)--\'04\'
        return @cid+@newid
end
您需要登录后才可以回帖 登录 | 成为会员

本版积分规则

QQ|手机版|小黑屋|网站帮助|职业IT人-IT人生活圈 ( 粤ICP备12053935号-1 )|网站地图
本站文章版权归原发布者及原出处所有。内容为作者个人观点,并不代表本站赞同其观点和对其真实性负责,本站只提供参考并不构成任何投资及应用建议。本站是信息平台,网站上部分文章为转载,并不用于任何商业目的,我们已经尽可能的对作者和来源进行了通告,但是能力有限或疏忽造成漏登,请及时联系我们,我们将根据著作权人的要求立即更正或者删除有关内容。

GMT+8, 2024-5-6 21:00 , Processed in 0.121116 second(s), 20 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表