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
麻烦帮忙写一下这个函数!!!谢谢啦!
...全文
114 点赞 收藏 9
写回复
9 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
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
你这个不好实现,还有很多前提条件,比如获取某个学生的入学年份,这样才有起始值可言
回复
相关推荐
发帖
应用实例
创建于2007-09-28

2.7w+

社区成员

MS-SQL Server 应用实例
申请成为版主
帖子事件
创建了帖子
2012-11-22 10:18
社区公告
暂无公告