sql server 用户自定义函数---学转换函数设计

whxw4482 2012-11-22 10:18:24
在sql server中怎么编写函数实现:如学年“2010-2011-1”对应于08级的同学应该是第5学期,函数作用是实现将形如“2010-2011-1”的学期表示形式转换为5的表示形式。
入口参数:学年,入学年份
返回值:数字表示的学期。
比如输入2011-2012-1,08 则返回7
麻烦帮忙写一下这个函数!!!谢谢啦!
...全文
187 9 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
csdnTimePeriod 2012-11-24
  • 打赏
  • 举报
回复
我想到的算法是 (cast(left(学年,4) as int)-cast(入学年份 as int))x2+right(学年,1)
whxw4482 2012-11-24
  • 打赏
  • 举报
回复
引用 5 楼 qianjin036a 的回复:
create function getsemester( @yyyy_mm as varchar(7),@grade as varchar(2) )returns int as begin declare @s int select @s=datediff(m,left(@yyyy_mm,2)+@grade+'-09-01',@yyyy_mm+'-01')/6+1 return @s……
虽然你没有按我的意思实现,但是我稍微修改了一下成功了。所以还是你的功劳,谢谢!!!!
-晴天 2012-11-22
  • 打赏
  • 举报
回复
说岔了,对08级,2010年1月是第三学期,5月是第四学期,10月是第五学期.
-晴天 2012-11-22
  • 打赏
  • 举报
回复
引用 3 楼 whxw4482 的回复:
不是,我的意思是说对于08年入学的同学来说“2010-2011-1”是第5学期
学期,是半年,你前面的2010,如果以全年来说的话,实际包含了三个学期,一月份是第4学期,5月份是第5学期,10月份是第6学期,你到底要哪个学期?
-晴天 2012-11-22
  • 打赏
  • 举报
回复
create function getsemester( @yyyy_mm as varchar(7),@grade as varchar(2) )returns int as begin declare @s int select @s=datediff(m,left(@yyyy_mm,2)+@grade+'-09-01',@yyyy_mm+'-01')/6+1 return @s end go select dbo.getsemester('2012-01','08') select dbo.getsemester('2011-10','08') /* ----------- 7 (1 行受影响) ----------- 7 (1 行受影响) */ go drop function dbo.getsemester
Vidor 2012-11-22
  • 打赏
  • 举报
回复
引用 3 楼 whxw4482 的回复:
不是,我的意思是说对于08年入学的同学来说“2010-2011-1”是第5学期
第4或第6如何表述,人脑如何区分,代码就怎么写,很有难度?
whxw4482 2012-11-22
  • 打赏
  • 举报
回复
不是,我的意思是说对于08年入学的同学来说“2010-2011-1”是第5学期
-晴天 2012-11-22
  • 打赏
  • 举报
回复
貌似参数应该是 2011-9-2012-1,否则 2011-5则是另一个学期
發糞塗牆 2012-11-22
  • 打赏
  • 举报
回复
你这个不好实现,还有很多前提条件,比如获取某个学生的入学年份,这样才有起始值可言

27,582

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 应用实例
社区管理员
  • 应用实例社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧