CSDN首页 空间 新闻 论坛 Blog 下载 读书 网摘 搜索 .NET Java 视频 接项目 求职 在线学习 买书 程序员 通知
可用分押宝游戏火热进行中... 专题改版:Java Web 专题
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  MS-SQL Server >  基础类

求一个带CASE的SQL自定义函数(50分)

楼主WL1001()2006-07-04 20:26:57 在 MS-SQL Server / 基础类 提问

参数有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

相关问题

关键词

得分解答快速导航

  • 帖主:WL1001
  • zjcxc

相关链接

  • SQL Server类图书

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
提问
网站简介|广告服务|VIP资费标准|银行汇款帐号|网站地图|帮助|联系方式|诚聘英才|English|问题报告
世纪乐知(北京)网络技术有限公司 版权所有, 京 ICP 证 020026 号
北京创新乐知广告有限公司 提供技术支持
Copyright © 2000-2007, CSDN.NET, All Rights Reserved
GongshangLogo