微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sqlserver用户自定义函数if判断

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

新来的同事需要写一个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.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐