SQL中如何截取日期
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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.用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来解决,这个现问题不建议这么做,这里只是一个思路
恩 谢谢
参考技术B 截取字符串,再转为日期格式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)
MSSQL
追答select SUBSTRING(convert(char,GetDate(),23),1,7)
sql如何截取日期字段中的年和月
sql如何截取日期字段中的年和月,日期字段中内容如"2008-12-01",现在让其截取出来显示为"200812"谢谢!
并不需要截取,通过year函数和month函数就可以解决。
比如字段名字叫startdate,类型是datetime。
获得字段中的年和月可用如下语句
select year(startdate) as 年,month(startdate) as 月 from 表名 参考技术A selectyear(getdate())
select
datepart(yy,getdate())
例如:
select
year(字段)
as
'年'
from
table_name
select
datepart(yy,字段)
as
'年'
from
table_name
用year()和datepart()函数都可以获取日期中的年。有问题可以追问或hi我。 参考技术B SELECT CAST(DATEPART(YEAR,GETDATE())AS VARCHAR)+CAST(DATEPART(MONTH,GETDATE()) AS VARCHAR)
方法很多啊 有需要就HI我 参考技术C SELECT DATENAME(yyyy, rq) + DATENAME(mm, rq) AS ny
from biao
返回的是字符型的本回答被提问者采纳
以上是关于SQL中如何截取日期的主要内容,如果未能解决你的问题,请参考以下文章