求一个带CASE的SQL自定义函数(50分)
参数有2个,一个是判断类型@no,另一个是被判断的字符串变量,返回一个逻辑值,语句表达意思就在下面,谁能帮我改一改,我是新手,实在不会做。
create function GET(@no int,@st varchar(10))
returns bit
as
begin
case @no
when 1 then returns (len(@st)=5)
when 2 then returns (left(@st,1)='2')
when 3 then returns (right(@st,1)='A')
…
end
end
go
问题点数:50、回复次数:6Top
1 楼LouisXIV(夜游神)回复于 2006-07-04 20:30:40 得分 0
没有看明白逻辑Top
2 楼zjcxc(邹建)回复于 2006-07-04 20:32:29 得分 50
create function GET(@no int,@st varchar(10))
returns bit
as
begin
return(convert(bit,
case @no
when 1 then case when len(@st)=5 then 1 else 0 end
when 1 then case when left(@st,1)='2' then 1 else 0 end
when 1 then case when right(@st,1)='A' then 1 else 0 end
end))
end
go
Top
3 楼LouisXIV(夜游神)回复于 2006-07-04 20:32:51 得分 0
貌似是要做判断,这样的语句不能用Case写,要用多重IF...ELSETop
4 楼zjcxc(邹建)回复于 2006-07-04 20:33:26 得分 0
sql中没有布尔类型, 所以 len(@st)=5 不是合法的表达式
而case when 是函数, 所以无法在里面用returnTop
5 楼LouisXIV(夜游神)回复于 2006-07-04 20:40:48 得分 0
Case原来还可以这样嵌套^^;
lz的逻辑来看,貌似是这样的
把老大的稍微修改一下
create function GET(@no int,@st varchar(10))
returns bit
as
begin
return(convert(bit,
case @no
when 1 then case when len(@st)=5 then 1 else 0 end
when 2 then case when left(@st,1)='2' then 1 else 0 end
when 3 then case when right(@st,1)='A' then 1 else 0 end
end))
end
goTop
6 楼WL1001()回复于 2006-07-04 20:43:18 得分 0
谢谢邹建兄,这么快就帮我解决了!Top




