加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sqlserver用户自定义函数if判断

发布时间:2020-12-12 15:36:40 所属栏目:MsSql教程 来源:网络整理
导读:最近项目开始验收,搜索那一块需要改造实在是忙

最近项目开始验收,搜索那一块需要改造实在是忙啊。

新来的同事需要写一个sql函数:

????? 查询表tb_wf_privgrant,但还需要根据表中的member_id,member_type两个字段来获取member_id对应的对象名称,其中member_type分为U——用户 ;G——组;R——角色...

她上周写了一个函数,我去执行都执行不了,后来发现一个查询出多条记录的语句赋给一个变量。

然后把我的思路告诉她:

?????定义一个函数如: 函数名(member_id,member_type)

???? 根据传进来的membertype,如果为U,则到用户表wf_org_user查询memberID对应的用户名;如果为G,则到组表wf_org_group查询memberID对应的组名;如果为D,则到机构表wf_org_department查询memberID对应的机构名,然后返回这查询出来的结果不就可以了

???? select 函数名(member_id,member_type),其他字段...? from? 表名

?

说了半天她还是不明白,改后发给我的还是传一个参数member_type,还问我怎么可能只有一条记录,怎么把参数传进去,看来是思维定式了,上周我说她把查询出来的多条记录赋给一个变量,她的思维还停留在那边。

没办法,最好只好说我帮她写,顺便也来温习一下:

--创建用户自定义函数
/****** 对象:? UserDefinedFunction [dbo].[MemberName]??? 脚本日期: 08/03/2009 11:18:15 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
create function [dbo].[MemberName](@member_Id varchar(32),@member_type char(1))
returns varchar(300)
as
? begin
? Declare @memberName varchar(300)
? if @member_type='R'
????????? begin
????????? set @memberName=(select name_ from wf_org_role where id_=@member_Id)
????????? end
? else if? @member_type='G'
????????? begin
????????? set @memberName=(select name_ from wf_org_group where id_=@member_Id)
????????? end
? else if? @member_type= 'D'
????????? begin
????????? set @memberName=(select name_ from wf_org_department where id_=@member_Id)
????????? end
? else if? @member_type= 'U'
????????? begin
????????? set @memberName=(select displayname_ from wf_org_user where id_=@member_Id)
????????? end
? return @memberName
? end

? --调用查询语句例子
? select dbo.MemberName(member_id,member_type),workflow_id,member_id,knowledge_code from tb_wf_privgrant

注意:

如果你这样来调用:
????? select MemberName(member_id,knowledge_code from tb_wf_privgrant?

可能会报:
?消息 195,级别 15,状态 10,第 1 行
'MemberName' 不是可以识别的 内置函数名称。

解决方案:

在自定义函数前加上所有者,如:dbo.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读