SQL中如何截取日期

日期为2012-03-19 时 截取年和月 (Es_paySlip为表格)
Select distinct(Year(cast(Es_paySlip.AddDate as datetime))) as StartYear from Es_paySlip --截取年
Select distinct(Month(cast(Es_paySlip.AddDate as datetime))) as StartMonth from Es_paySlip --截取日
如果日期换为 2011年1月 时 该怎么截取年和月

第1个回答  2013-02-07
参考做法:
1.用Replace()函数把时间中的“年”,“月”用“-”进行替换,
2.再转换成Datetime类型数据,用Month(),Year()函数获取月和时间

select month(cast(replace(replace(@timeStr,'年','-'),'月','-') as datetime))

或者使用原始的方法 用“年”,“月”来定位获取“年”前的数据位年,“年”“月”之间的数据位月;

上边这种方法应该方便一点,同时注意转换的格式追问

是这样替换么?
select month(cast(replace(replace('2013年10月','年','-'),'月','-') as datetime))

可是结果显示 : 从字符串向 datetime 转换时失败。

追答

select month(cast(replace(replace('2013年10月','年','-'),'月','') as datetime)),

另外:如果用SQL脚本使用起来很麻烦,愿意使用C#代码解决这个问题也可在数据库中注册入DLL来解决,这个现问题不建议这么做,这里只是一个思路

追问

恩 谢谢

第2个回答  2013-02-07
截取字符串,再转为日期格式
SELECT CONVERT(DATE,SUBSTRING('2013年10月',1,4)+SUBSTRING('2013年10月',6,2)+'01',108)追问

我试了一下 结果是这个 2013-10-01 00:00:00.000 我要截取的是单个年 和单个月 分两次SQL语句截取

追答

SELECT SUBSTRING('2013年10月',1,4)
SELECT SUBSTRING('2013年10月',6,2)

第3个回答  2013-02-07
select left(col,4) as 年,substring(col,6,charindex('月',col)-charindex('年',col)-1) as 月
第4个回答  2013-02-07
Select LEFT('2011年2月',4) as Year ,LEFT(right('2011年2月',2),1) as Month本回答被提问者采纳
第5个回答  2013-02-07
什么数据库 oracle?MSSQL?追问

MSSQL

追答

select SUBSTRING(convert(char,GetDate(),23),1,7)