楼主应该不会使用的是如何取去年,或者上个月吧?
其实有很多种获取方法,比如:
convert(nvarchar(7),dateadd(month,-1,getdate()),23)--获取上个月,出现格式2016-12
year(getdate())-1 --上一年
另外可以再介绍几种常用函数:
getdate()--获取当前时间
year(时间字段)--获取时间字段的年
Month(时间字段)--获取时间字段的月
Day(时间字段)--获取时间字段的日
Dateadd(时间类型,相距数量,时间字段)--计算与时间字段相距的日期,时间类型可以是年月日时分秒等等
Datediff(时间类型,时间1,时间2)--计算两个时间的时间差,类型与上一个一致
在函数CONVERT()中你可以使用许多种不同风格的日期和时间格式。表111显示了所有的格式。
表111日期和时间的类型
类型值标准输出
0Defaultmonddyyyyhh:miAM
1USAmm/dd/yy
2ANSIyymmdd
3British/Frenchdd/mm/yy
4Germanddmmyy
5Italiandd-mm-yy
6-ddmonyy
7-mondd,yy
8-hh:mi:ss
9Default--monddyyyy
hh:mi:ss:mmmAM(or)
10USAmm-dd-yy
11JAPANyy/mm/dd
12ISOyymmdd
13EuropeDefault--ddmonyyyy
hh:mi:ss:mmm(24h)
14-hh:mi:ss:mmm(24h)
类型0,9,和13总是返回四位的年。对其它类型,要显示世纪,把style值加上100。类型13和14返回24小时时钟的时间。类型0,7,和13返回的月份用三位字符表示(用Nov代表November)
对表111中所列的每一种格式,你可以把类型值加上100来显示有世纪的年(例如,00年将显示为2000年)。例如,要按日本标准显示日期,包括世纪,你应使用如下的语句:
SELECTCONVERT(VARCHAR(30),GETDATE(),111)
在这个例子中,函数CONVERT()把日期格式进行转换,显示为1997/11/30
工具/材料:Management Studio。
1、首先在桌面上,点击“Management Studio”图标。
2、之后在该界面中,点击左上角“新建查询”选项。
3、接着在该界面中,输入获取今年的上一年和下一年(去年与明年)的sql语句“select year(getdate())-1 AS "去年" , year(getdate())+1 AS "明年"”。
4、然后在该界面中,点击左上方“执行”按钮。
5、最后在该界面中,显示获取今年的上一年和下一年(去年与明年)成功。
mysql> select DATE_FORMAT('1997-10-04 22:23:00', '%Y/%m ');
+----------------------------------------------+
| DATE_FORMAT('1997-10-04 22:23:00', '%Y/%m ') |
+----------------------------------------------+
| 1997/10 |
+----------------------------------------------+
Year(@time), Month(@time) 2 个函数即可。
然后用它们来组装字符串也就简单了。
CONVERT(VarChar(7), @time, 120)会得到YYYY-MM。调用。
用转成字符串,,但此时他已经不是时间类型。
CONVERT(char(7),"你的时间例",120)
GETDATE() 函数从 SQL Server 返回当前的时间和日期。
使用下面的 SELECT 语句:
SELECT GETDATE() AS CurrentDateTime
结果:
CurrentDateTime
2008-12-29 16:25:46635
注释:上面的时间部分精确到毫秒。
例子 2
下面的 SQL 创建带有日期时间列 (OrderDate) 的 "Orders" 表:
CREATE TABLE Orders
(
OrderId int NOT NULL PRIMARY KEY,
ProductName varchar(50) NOT NULL,
OrderDate datetime NOT NULL DEFAULT GETDATE()
)
请注意,OrderDate 把 GETDATE() 规定为默认值。结果是,当您在表中插入新行时,当前日期和时间自动插入列中。
现在,我们希望在 "Orders" 表中插入一条记录:
INSERT INTO Orders (ProductName) VALUES ('Computer')
"Orders" 表将成为这样:
OrderId ProductName OrderDate
1 'Computer' 2008-12-29 16:25:46635
因为这个时候time是datetime类型,left是针对字符串的 *** 作,先把time转换为字符串就可以了
select left(convert(varchar,getdate(),21),7)
以上就是关于取上个月和上一年的数据的sql怎么写全部的内容,包括:取上个月和上一年的数据的sql怎么写、sql时间格式转换(sql时间格式转换年月)、oracle的sql 如何获取今年的上一年和下一年(去年与明年)等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)