最近项目开始验收,搜索那一块需要改造实在是忙啊。
新来的同事需要写一个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.
(编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|