sql
server:
取年:
year(时间)
或者datepart(year,时间)
取月:
month(时间)或者datepart(month,时间)
oracle:
取年:
extract(year
from
时间)
或者
to_char(时间,'yyyy')
取月:
extract(month
from
时间)
或者
to_char(时间,'mm')
当然,上述前提都是你的时间是时间类型的,比如sql
server中是datetime类型,oracle中是date类型的
如果时间本来就是用字符串形式存储的,那直接根据格式用字符串函数处理就可以了
需要设置函数公式select from 表名 where Convert(varchar(10),日期字段,120)='2008-12-15'即可输出。
如获取年月日,设置 select CONVERT(varchar(100), GETDATE(), 23)
输出2017-03-06 ,如需获取年月
select CONVERT(varchar(7), GETDATE(), 120)
输出变为2017-03。
1、结构化查询语言(Structured Query Language)简称SQL,是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;同时也是数据库脚本文件的扩展名。
2、结构化查询语言包含6个部分:数据查询语言(DQL:Data Query Language);数据 *** 作语言(DML:Data Manipulation Language);事务处理语言(TPL);数据控制语言(DCL);数据定义语言(DDL);和指针控制语言(CCL)。
资料来源:SQL 教程-函数设置
SELECT CAST(@YearDiff AS NVARCHAR(10)) + '年' + CAST(@MonthDiff AS NVARCHAR(10)) + '月' + CAST(@DayDiff AS NVARCHAR(10)) + '日'!
这要看具体是那种数据库了,有些数据库中,两个日期可以直接相减,得到的是相差的天数,也有些数据库可以把两个日期相减,得到的结果可以指定是相差的年数、月份数、天数、小时数、分钟数或者秒数。
select @diffdate=select datediff(month,'2005-4-10','2005-7-10')
这里改成:
select @diffdate=(select datediff(month,'2005-4-10','2005-7-10'))
增加一个括号而已
以上,完毕
以上就是关于SQL如何取年月全部的内容,包括:SQL如何取年月、sql 如何取日期中的年月、计算两个时间相差多少年月日的sql算法等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)