sql日期函数
sql_时间函数大全
1. 当前系统日期、时间select getdate()2. dateadd 在向指定日期加上一段时间的基础上,返回新的datetime 值例如:向日期加上2天select dateadd(day,2,'2004-10-15') --返回:2004-10-17 00:00:00.0003. datediff 返回跨两个指定日期的日期和时间边界数。
select datediff(day,'2004-09-01','2004-09-18') --返回:174. datepart 返回代表指定日期的指定日期部分的整数。
SELECT DATEPART(month, '2004-10-15') --返回105. datename 返回代表指定日期的指定日期部分的字符串SELECT datename(weekday, '2004-10-15') --返回:星期五6. day(), month(),year() --可以与datepart对照一下select 当前日期=convert(varchar(10),getdate(),120),当前时间=convert(varchar(8),getdate(),114)select datename(dw,'2004-10-15')select 本年第多少周=datename(week,'2004-10-15'),今天是周几=datename(weekday,'2004-10-15')函数参数/功能GetDate( ) 返回系统目前的日期与时间DateDiff (interval,date1,date2) 以interval 指定的方式,返回date2 与date1两个日期之间的差值date2-date1DateAdd (interval,number,date) 以interval指定的方式,加上number之后的日期DatePart (interval,date) 返回日期date中,interval指定部分所对应的整数值DateName (interval,date) 返回日期date中,interval指定部分所对应的字符串名称参数interval的设定值如下:值缩写(Sql Server)(Access 和ASP) 说明Year Yy yyyy 年1753 ~ 9999Quarter Qq q 季1 ~ 4Month Mm m 月1 ~ 12Day of year Dy y 一年的日数,一年中的第几日1-366Day Dd d 日,1-31Weekday Dw w 一周的日数,一周中的第几日1-7Week Wk ww 周,一年中的第几周0 ~ 51Hour Hh h 时0 ~ 23Minute Mi n 分钟0 ~ 59Second Ss s 秒0 ~ 59Millisecond Ms - 毫秒0 ~ 999access 和asp 中用date()和now()取得系统日期时间;其中DateDiff,DateAdd,Dat ePart也同是能用于Access和asp中,这些函数的用法也类似举例:1.GetDate() 用于sql server :select GetDate()2.DateDiff('s','2005-07-20','2005-7-25 22:56:32')返回值为514592 秒DateDiff('d','2005-07-20','2005-7-25 22:56:32')返回值为5 天3.DatePart('w','2005-7-25 22:56:32')返回值为2 即星期一(周日为1,周六为7) DatePart('d','2005-7-25 22:56:32')返回值为25即25号DatePart('y','2005-7-25 22:56:32')返回值为206即这一年中第206天DatePart('yyyy','2005-7-25 22:56:32')返回值为2005即2005年2. 查询某个日期之间的记录数据:select * from t_business_product where hit_count>1000 and last_date>'20 05-02-01' and last_date<='2005-06-05'order by id descgo查询最近一个月内的点击率大于100的记录数据:select * from t_business_product where hit_count>100 and datediff(Dd,last _date,getdate())<=30 order by id descgo查询最近一周内的点击率大于100的记录数据:select * from t_business_product where hit_count>100 and datediff(Dw,las t_date,getdate())<=7 order by id descgo查询某一年(如2006年)点击率大于300的记录数据:select * from t_business_product where hit_count>300 and DatePart(Yy,las t_date)=2006 order by id descgo或select * from t_business_product where hit_count>300 and DatePart(Year,l ast_date)=2006 order by id descgo3. SQL Server中文版的默认的日期字段datetime格式是yyyy-mm-dd Thh:m m:ss.mmm例如:select getdate()2004-09-12 11:06:08.177整理了一下SQL Server里面可能经常会用到的日期格式转换方法:举例如下:select CONVERT(varchar, getdate(), 120 )2004-09-12 11:06:08select replace(replace(replace(CONVERT(varchar, getdate(), 120 ),'-',''),' ',' '),':','')20040912110608select CONVERT(varchar(12) , getdate(), 111 )2004/09/12select CONVERT(varchar(12) , getdate(), 112 )20040912select CONVERT(varchar(12) , getdate(), 102 )2004.09.12select CONVERT(varchar(12) , getdate(), 101 )09/12/2004select CONVERT(varchar(12) , getdate(), 103 )12/09/2004select CONVERT(varchar(12) , getdate(), 104 )12.09.2004select CONVERT(varchar(12) , getdate(), 105 )12-09-2004select CONVERT(varchar(12) , getdate(), 106 )12 09 2004select CONVERT(varchar(12) , getdate(), 107 )09 12, 2004select CONVERT(varchar(12) , getdate(), 108 )11:06:08select CONVERT(varchar(12) , getdate(), 109 )09 12 2004 1select CONVERT(varchar(12) , getdate(), 110 )09-12-2004select CONVERT(varchar(12) , getdate(), 113 )12 09 2004 1select CONVERT(varchar(12) , getdate(), 114 )11:06:08.1774. CAST 和CONVERT将某种数据类型的表达式显式转换为另一种数据类型。
SQLPLSQL日期函数总结
SQLPLSQL日期函数总结日期函数在SQL/PLSQL中用于对日期进行计算和操作。
下面是一些常用的日期函数总结。
1.SYSDATE函数:SYSDATE函数用于返回系统当前日期和时间。
它返回一个日期值,包含当前日期和时间的年、月、日、时、分和秒。
2.CURRENT_DATE函数:CURRENT_DATE函数与SYSDATE函数功能相似,返回系统当前日期,但没有时间部分。
3.CURRENT_TIMESTAMP函数:CURRENT_TIMESTAMP函数返回包含当前日期和时间的时间戳。
4.TO_DATE函数:TO_DATE函数用于将一个字符串转换为日期。
它接受两个参数:带日期的字符串和日期格式模型。
例如,TO_DATE('2024-08-15','YYYY-MM-DD')返回一个日期值。
5.TO_CHAR函数:TO_CHAR函数用于将一个日期值转换为字符串。
它接受两个参数:日期值和日期格式模型。
例如,TO_CHAR(SYSDATE,'YYYY-MM-DD')返回当前日期的字符串表示。
6.ADD_MONTHS函数:ADD_MONTHS函数用于在给定日期上添加指定的月份数。
它接受两个参数:日期值和要添加的月份数。
例如,ADD_MONTHS(SYSDATE,3)返回当前日期的三个月后的日期。
7.MONTHS_BETWEEN函数:MONTHS_BETWEEN函数用于计算两个日期之间的月份数。
它接受两个参数:两个日期值。
例如,MONTHS_BETWEEN('2024-01-01','2024-01-01')返回两个日期之间的月份数。
8.EXTRACT函数:EXTRACT函数用于从日期中提取指定的部分。
它接受两个参数:要提取的部分(如年、月、日)和日期值。
例如,EXTRACT(YEARFROMSYSDATE)返回当前日期的年份。
9.TRUNC函数:TRUNC函数用于截断日期部分,并返回一个新的日期值。
sql常用函数及用法
sql常用函数及用法SQL是一种使用结构化查询语言来管理关系数据库系统的编程语言。
在SQL中,有许多常用函数可用于在查询中计算结果值。
常用函数通常包括聚合函数、字符串函数、日期和时间函数、数学函数、条件函数等。
以下是SQL常用函数及其用法的参考内容。
1. 聚合函数聚合函数在SQL中用于计算和汇总数据。
最常用的聚合函数是SUM、AVG、MAX和MIN。
例如:SELECT SUM(salary) FROM employee;这将返回员工表中所有员工的总工资。
2. 字符串函数字符函数用于处理文本数据。
最常用的字符函数是LEN、UPPER、LOWER、SUBSTRING和CONCAT。
例如:SELECT UPPER(last_name) FROM employee;这将返回所有员工的姓氏的大写形式。
3. 日期和时间函数日期和时间函数用于处理日期和时间数据。
最常用的日期和时间函数是NOW、YEAR、MONTH、DAY和HOUR。
例如:SELECT YEAR(hire_date) FROM employee;这将返回每个员工被雇用的年份。
4. 数学函数数学函数用于计算数值数据。
最常用的数学函数是ABS、ROUND、CEILING和FLOOR。
例如:SELECT ABS(salary) FROM employee;这将返回员工工资的绝对值。
5. 条件函数条件函数根据给定的条件返回不同的结果。
最常用的条件函数是IF、CASE和COALESCE。
例如:SELECT IF(salary>50000, "High", "Low") FROM employee;这将返回“高”或“低”,具体取决于每个员工的工资是否大于50000。
总的来说,SQL中的常用函数可以大大简化数据处理和查询操作。
在实际使用时,根据需要选择适当的函数和参数可以大大提高工作效率。
SQL日期函数大全
通常,你需要获得当前日期和计算一些其他的日期,例如,你的程序可能需要判断一个月的第一天或者最后一天。
你们大部分人大概都知道怎样把日期进行分割(年、月、日等),然后仅仅用分割出来的年、月、日等放在几个函数中计算出自己所需要的日期!在这篇文章里,我将告诉你如何使用DATEADD和DATEDIFF函数来计算出在你的程序中可能你要用到的一些不同日期。
在使用本文中的例子之前,你必须注意以下的问题。
大部分可能不是所有例子在不同的机器上执行的结果可能不一样,这完全由哪一天是一个星期的第一天这个设置决定。
第一天(DATEFIRST)设定决定了你的系统使用哪一天作为一周的第一天。
所有以下的例子都是以星期天作为一周的第一天来建立,也就是第一天设置为7。
假如你的第一天设置不一样,你可能需要调整这些例子,使它和不同的第一天设置相符合。
你可以通过@@DATEFIRST函数来检查第一天设置。
为了理解这些例子,我们先复习一下DATEDIFF和DATEADD函数。
DATEDIFF函数计算两个日期之间的小时、天、周、月、年等时间间隔总数。
DATEADD函数计算一个日期通过给时间间隔加减来获得一个新的日期。
要了解更多的DATEDIFF和DATEADD函数以及时间间隔可以阅读微软联机帮助。
使用DATEDIFF和DATEADD函数来计算日期,和本来从当前日期转换到你需要的日期的考虑方法有点不同。
你必须从时间间隔这个方面来考虑。
比如,从当前日期到你要得到的日期之间有多少时间间隔,或者,从今天到某一天(比如1900-1-1)之间有多少时间间隔,等等。
理解怎样着眼于时间间隔有助于你轻松的理解我的不同的日期计算例子。
一个月的第一天第一个例子,我将告诉你如何从当前日期去这个月的最后一天。
请注意:这个例子以及这篇文章中的其他例子都将只使用DATEDIFF和DATEADD函数来计算我们想要的日期。
每一个例子都将通过计算但前的时间间隔,然后进行加减来得到想要计算的日期。
SQL日期函数daymonthyear各种使用方法
SQL日期函数daymonthyear各种使用方法1. day(函数:- day(date): 返回指定日期中的天数。
- 示例:SELECT day('2024-09-01'); 返回结果为12. month(函数:- month(date): 返回指定日期中的月份。
- 示例:SELECT month('2024-09-01'); 返回结果为93. year(函数:- year(date): 返回指定日期中的年份。
- 示例:SELECT year('2024-09-01'); 返回结果为2024在使用day(、month(、year(函数时,需要注意以下几点:1.日期格式:-在使用这些函数之前,需要确保传递的日期参数是有效的日期格式,通常是YYYY-MM-DD。
-若日期格式不正确,函数可能会返回错误或无效的结果。
2.使用数据库特定的日期函数:-不同的数据库管理系统可能有不同的日期函数语法和用法。
-在编写SQL查询时,需要根据所使用的数据库系统来使用正确的日期函数。
3.使用与日期函数相关的其他函数:-日期函数还可以与其他函数一起使用来处理和获取更复杂的日期信息。
- 例如,可以将day(、month(和year(函数与聚合函数(如SUM、COUNT等)一起使用,以计算段时间内的总天数、月份数或年份数。
下面是一些使用day(、month(、year(函数的示例:1.获取当前日期的天数、月份和年份:- SELECT day(current_date);- SELECT month(current_date);- SELECT year(current_date);2.获取一些日期的天数、月份和年份:- SELECT day('2024-09-01');- SELECT month('2024-09-01');- SELECT year('2024-09-01');3.对日期字段进行筛选:- SELECT * FROM table WHERE day(date_column) = 1;- SELECT * FROM table WHERE month(date_column) = 9;- SELECT * FROM table WHERE year(date_column) = 2024;4.计算两个日期之间的天数差:- SELECT datediff(date1, date2);- 示例:SELECT datediff('2024-09-10', '2024-09-01'); 返回结果为95.获取当前日期的加减操作:- SELECT current_date + interval 1 day; (当前日期加1天)- SELECT current_date - interval 1 month; (当前日期减去1个月)- SELECT current_date + interval 1 year; (当前日期加1年)以上示例仅演示了day(、month(、year(函数的基本用法,并且可能因不同的数据库而有所差异。
SQLServer日期函数大全(小结)
SQLServer⽇期函数⼤全(⼩结)⼀、统计语句1、--统计当前【>当天00点以后的数据】SELECT * FROM 表 WHERE CONVERT(Nvarchar, dateandtime, 111) = CONVERT(Nvarchar, GETDATE(), 111) ORDER BY dateandtime DESC 2、--统计本周SELECT * FROM 表 WHERE datediff(week,[dateadd],getdate())=03、--统计本⽉SELECT * FROM 表 WHERE datediff(month,[dateadd],getdate())=04、统计当前SELECT * FROM 表 WHERE datediff(day,[dateadd],getdate())=0Select * From table with(nolock) Where Convert(varchar(10),[CreateTime],120) = Convert(varchar(10),getDate(),120)⼆、时间函数1、当前系统⽇期、时间select getdate()2、dateadd 在向指定⽇期加上⼀段时间的基础上,返回新的 datetime 值,例如:向⽇期加上2天select dateadd(day,2,'2004-10-15') --返回:2004-10-17 00:00:00.0003、datediff 返回跨两个指定⽇期的⽇期和时间边界数select datediff(day,'2004-09-01','2004-09-18') --返回:174、datepart 返回代表指定⽇期的指定⽇期部分的整数SELECT DATEPART(month, '2004-10-15') --返回 105、datename 返回代表指定⽇期的指定⽇期部分的字符串SELECT datename(weekday, '2004-10-15') --返回:星期五6、day(), month(),year() --可以与datepart对照⼀下select 当前⽇期=convert(varchar(10),getdate(),120),select 当前时间=convert(varchar(8),getdate(),114),select datename(dw,'2004-10-15')select 本年第多少周=datename(week,'2004-10-15'),select 今天是周⼏=datename(weekday,'2004-10-15')7、求相差天数select datediff(day,'2004-01-01',getdate())8、⼀个⽉第⼀天的SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)9、本周的星期⼀SELECT DATEADD(wk, DATEDIFF(wk,0,getdate()), 0)select dateadd(wk,datediff(wk,0,getdate()),6)10、⼀年的第⼀天SELECT DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)11、季度的第⼀天SELECT DATEADD(qq, DATEDIFF(qq,0,getdate()), 0)12、当天的半夜SELECT DATEADD(dd, DATEDIFF(dd,0,getdate()), 0)13、上个⽉的最后⼀天SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))14、去年的最后⼀天SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))15、本⽉的最后⼀天SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0))16、本年的最后⼀天SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0))17、本⽉的第⼀个星期⼀select DATEADD(wk, DATEDIFF(wk,0,dateadd(dd,6-datepart(day,getdate()),getdate())), 0)18、查询本周注册⼈数select count(*) from [user]where datediff(week,create_day-1,getdate())=019、上周注册⼈数select count(*) from [user]where datediff(week,create_day-1,getdate())=120、本⽉注册⼈数select count(*) from [user]where datediff(month,create_day,getdate())=021、上⽉注册⼈数select count(*) from [user]where datediff(month,create_day,getdate())=1如果要效率,⽤⼀下⽅式22、查询本周注册⼈数select count(*) from [user]where create_day>=dateadd(day,2-datepart(weekday,getdate()),convert(varchar,getdate(),112)) and create_day<dateadd(day,9-datepart(weekday,getdate()),convert(varchar,getdate(),112))23、上周注册⼈数select count(*) from [user]where create_day>=dateadd(day,-5-datepart(weekday,getdate()),convert(varchar,getdate(),112)) and create_day<dateadd(day,2-datepart(weekday,getdate()),convert(varchar,getdate(),112))24、本⽉注册⼈数select count(*) from [user]where create_day>=dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))and create_day<dateadd(month,1,dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))) 25、上⽉注册⼈数select count(*) from [user]where create_day>=dateadd(month,-1,dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))) and create_day<dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))26、本周select count(*) from Userwhere datediff(dd,create_day,getdate()) <= datepart(dw,getdate())27、上周select count(*) from Userwhere datediff(dd,create_day,(getdate() - datepart(dw,getdate()))) <= 728、本⽉select count(*) from Userwhere datepart(mm,create_day) = datepart(mm,getdate())29、上⽉select count(*) from Userwhere datepart(mm,create_day) = datepart(mm,getdate()) - 130、本周注册⼈数select count(*) from [User]where datediff(dd,create_day,getdate()) <= datepart(dw,getdate())31、上周注册⼈数select count(*) from [User]where datediff(dd,create_day,(getdate() - datepart(dw,getdate()))) <= 732、本⽉注册⼈数select count(*) from [User]where datepart(mm,create_day) = datepart(mm,getdate())33、上⽉注册⼈数select count(*) from [User]where datepart(mm,create_day) = datepart(mm,getdate()) - 134、查询今⽇所有SELECT * from feedback WHERE (DATEDIFF(d,fedtime,GETDATE())=0) ORDER BY fedid DESCmonth(create_day)=month(getdate())本⽉month(create_day)=month(getdate())-1 上⽉今天的所有数据:select * from 表名 where DateDiff(dd,datetime类型字段,getdate())=0昨天的所有数据:select * from 表名 where DateDiff(dd,datetime类型字段,getdate())=17天内的所有数据:select * from 表名 where DateDiff(dd,datetime类型字段,getdate())<=730天内的所有数据:select * from 表名 where DateDiff(dd,datetime类型字段,getdate())<=30本⽉的所有数据:select * from 表名 where DateDiff(mm,datetime类型字段,getdate())=0本年的所有数据:select * from 表名 where DateDiff(yy,datetime类型字段,getdate())=0系统函数:函数参数/功能GetDate( )返回系统⽬前的⽇期与时间DateDiff (interval,date1,date2)以interval 指定的⽅式,返回date2 与date1两个⽇期之间的差值 date2-date1 DateAdd (interval,number,date)以interval指定的⽅式,加上number之后的⽇期DatePart (interval,date)返回⽇期date中,interval指定部分所对应的整数值DateName (interval,date)返回⽇期date中,interval指定部分所对应的字符串名称参数 interval的设定值:值缩写(Sql Server)Access 和 ASP说明Year Yy yyyy年 1753 ~ 9999Quarter Qq q季 1 ~ 4Month Mm m⽉1 ~ 12Day of year Dy y⼀年的⽇数,⼀年中的第⼏⽇ 1-366Day Dd d⽇,1-31Weekday Dw w⼀周的⽇数,⼀周中的第⼏⽇ 1-7Week Wk ww周,⼀年中的第⼏周 0 ~ 51Hour Hh h时0 ~ 23Minute Mi n分钟0 ~ 59Second Ss s秒 0 ~ 59Millisecond Ms-毫秒 0 ~ 999access 和 asp 中⽤date()和now()取得系统⽇期时间;其中DateDiff,DateAdd,DatePart也同是能⽤于Access和asp中,这些函数的⽤法也类似举例:1.GetDate() ⽤于sql server :select GetDate()2.DateDiff('s','2005-07-20','2005-7-25 22:56:32')返回值为 514592 秒DateDiff('d','2005-07-20','2005-7-25 22:56:32')返回值为 5 天3.DatePart('w','2005-7-25 22:56:32')返回值为 2 即星期⼀(周⽇为1,周六为7)DatePart('d','2005-7-25 22:56:32')返回值为 25即25号DatePart('y','2005-7-25 22:56:32')返回值为 206即这⼀年中第206天DatePart('yyyy','2005-7-25 22:56:32')返回值为 2005即2005年Sql 取当天或当⽉的记录表中的时间格式是这样的:2007-02-02 16:50:08.050, 如果直接和当天的时间⽐较,就总得不到准确数据,但是我们可以把这种格式的时间[格式化]成 2007-02-02,也就是只有年-⽉-⽇,然后把当天的时间也格式化成年-⽉-⽇的格式.这样,思路就出来了!我们格式化⽇期要⽤到 Convert()这个函数,要⽤到3个参数,⾸先来格式化当天的⽇期,Convert(varchar(10),getDate(),120)这样我们就可以把当天的⽇期格式化为: 2007-2-2,然后格式化数据库表中的⽇期Convert(varchar(10),TimeFiled,120),最后我们就可以⽤⼀条Sql语句得到当天的数据了.例如:Select * From VIEW_CountBill Where Convert(varchar(10),[time],120) = Convert(varchar(10),getDate(),120)注意:Convert()函数中的各个参数的意义,第⼀个参数,varchar(10)是⽬标系统所提供的数据类型,包括 bigint 和 sql_variant。
Access常用内置SQL函数
Access常⽤内置SQL函数⼀、Access常⽤内置SQL函数---⽇期时间函数1.CDate说明:将字符串转化成为⽇期举例:select CDate("2008/4/5")2.Date说明:返回当前⽇期举例:select Date()3.DateAdd说明:将指定⽇期加上某个⽇期举例:select dateAdd("d",30,Date()),其中d可以换为yyyy或H等4.DateDiff说明:判断两个⽇期之间的间隔举例:select DateDiff("d","2008-5-1",now) 其中d可以换为yyyy或H等5.DatePart说明:返回⽇期的某个部分举例:select DatePart("d","2008-5-1")返回1,即1号,d也可以换为yyyy或m6.Day说明:返回⽇期的d部分,等同于datepart的d部分举例:select Day("2008-5-1")返回1,即1号7.Hour说明:返回⽇期的⼩时举例:select Hour("2008-5-1 18:25:14")返回18,即18点8.IsDate说明:判断是否是⽇期,是⽇期返回-1,不是⽇期返回0举例:select IsDate("2008-5-1 18:25:14")9.Minute 返回⽇期的分钟部分说明:返回⽇期的分钟部分举例:select Minute("2008-5-1 18:25:14")返回25,即25分10.Month说明:返回⽇期的⽉份部分举例:select Month("2008-5-1 18:25:14")返回5,即5⽉11.Now说明: 返回当前时间(年⽉⽇时分秒)举例:select Now()12.Second说明:返回⽇期的秒部分举例:select Second("2008-5-1 18:25:14")返回14,即14秒13.Time说明:返回当前的时间部分举例:select Time()14.weekday说明:返回某个⽇期的当前星期(星期天为1,星期⼀为2,星期⼆为3 ...)举例:select weekday(now())15.Year说明:返回某个⽇期的年份举例:select Year("2008-5-1 18:25:14")返回2008,即2008年⼆、 Access常⽤内置SQL函数---⽂本字符串函数说明:返回字母的Acsii值举例:select Asc("A")返回652.Chr说明:将ascii值转换到字符举例:select chr(65)返回"A"3.Format说明:格式化字符串举例:Select Format(now(),"yyyy-mm-dd")返回类似于"2008-04-03" Select Format(3/9,"0.00")返回0.334.InStr说明:查询⼦串在字符串中的第⼀个出现的位置,没有返回0举例:select Instr("abc","a") 返回15.LCase说明:返回字符串的⼩写形式举例:select LCase("ABC") 返回"abc"6.Left说明:左截取字符串举例:select Left("ABC",1) 返回"A"7.Len说明:返回字符串长度举例:select Len("ABC你好")返回58.LTrim说明:左截取空格举例:select LTrim(" 111") 返回"111"9.Mid说明:取得⼦字符串举例:select mid("abcd",1,2) 返回"ab"10.Right说明:右截取字符串举例:select Right("ABC",1) 返回"C"11.RTrim说明:右截取空格举例:select Right("ABC ") 返回"ABC"12.Space说明:产⽣空格举例:select Space(5) 返回5个空格13.StrComp说明:⽐较两个字符串是否内容⼀致(不区分⼤⼩写)举例:select StrComp("abc","ABC")返回0select StrComp("abc","123")返回-114.Trim说明:截取字符串两头的空格举例:select Trim(" ABC ") 返回"ABC"15.UCase说明:将字符串转⼤写举例:select UCase("abc") 返回"ABC"三、 Access常⽤内置SQL函数---统计类函数说明:取字段平均值2.Count说明:统计记录条数3.Max说明:取字段最⼤值4.Min说明:取字段最⼩值5.StDev说明:估算样本的标准差(忽略样本中的逻辑值和⽂本)6.StDevP说明:计算以参数形式(忽略逻辑值和⽂本)给出的整个样本总体的标准偏差7.Sum说明:计算字段的总合8.Var说明:估算样本⽅差(忽略样本中的逻辑值和⽂本)9.VarP说明:计算整个样本总体的⽅差(忽略样本总体中的逻辑值和⽂本)。
SQL日期函数大全
select case datediff(day,datename(year,getdate())+'-02-01',dateadd(mm,1,datename(year,getdate())+'-02-01'))
when 28 then '平年' else '闰年' end
SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)
我们把这个语句分开来看看它是如何工作的。最核心的函数是getdate(),大部分人都知道这个是返回当前的日期和时间的函数。下一个执行的函数DATEDIFF(mm,0,getdate())是计算当前日期和“1900-01-01 00:00:00.000”这个日期之间的月数。记住:时期和时间变量和毫秒一样是从“1900-01-01 00:00:00.000”开始计算的。这就是为什么你可以在DATEDIFF函数中指定第一个时间表达式为“0”。下一个函数是DATEADD,增加当前日期到“1900-01-01”的月数。通过增加预定义的日期“1900-01-01”和当前日期的月数,我们可以获得这个月的第一天。另外,计算出来的日期的时间部分将会是“00:00:00.000”。
连接上面的例子,为了要得到去年的最后一天,你需要在今年的第一天上减去3毫秒。
SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))
本月的最后一天
现在,为了获得本月的最后一天,我需要稍微修改一下获得上个月的最后一天的语句。修改需要给用DATEDIFF比较当前日期和“1900-01-01”返回的时间间隔上加1。通过加1个月,我计算出下个月的第一天,然后减去3毫秒,这样就计算出了这个月的最后一天。这是计算本月最后一天的SQL脚本。
SQL日期函数加减法
5 日期转换函数 CONVERT CAST
CONVERT 中的 Style. 参数:108 和 114 可以只得到时间。
例 SELECT CONVERT(NVARCHAR(12),GETDATE(),108) ---12:41:15
SELECT CONVERT(NVARCHAR(12),GETDATE(),114) ---12:43:12:590
Else
Select @RE = @A2
Return @RE
END
Go
Select * From Table
Order By
Dbo.UF_MAX(Dbo.UF_MAX(Sale1,Sale2),Sale3) DESC
注:datepart 指定应在日期的哪一部分计算差额的参数,其日期相减时,只关注边界值,例SELECT DATEDIFF(YEAR,'2008-12-31','2009-1-1') 返回 1
DATEADD : 返回给指定日期加上一个时间间隔后的新 datetime 值。 语法:DATEADD (datepart , number, date )
SELECT DATEADD(Quarter,DATEDIFF(Quarter,0,GETDATE()),0)
注:首先DATEDIFF(Quarter,0,GETDATE()) --计算当前月份与 1900年相差的季份数,然后通过计算1900-1-1加上相差的季份数的日期即为当季第一天
union
select * from tablename
order by case when sale1 > sale2 and sale1 > sale3 then sale1
my sql时间函数
my sql时间函数
MySQL提供了许多用于处理日期和时间的内置函数,这些函数可以帮助我们执行各种操作,例如提取日期部分、执行日期计算、格式化日期等。
以下是一些常用的MySQL时间函数:
1. CURDATE(): 返回当前日期。
2. CURTIME(): 返回当前时间。
3. NOW(): 返回当前日期和时间。
4. DATE_FORMAT(date, format): 将日期按照指定的格式进行格式化。
5. DATE_ADD(date, INTERVAL expr type): 将日期加上指定的时间间隔。
6. DATE_SUB(date, INTERVAL expr type): 从日期中减去指定的时间间隔。
7. DATEDIFF(date1, date2): 返回两个日期之间的天数差。
8. TIMEDIFF(time1, time2): 返回两个时间之间的时间差。
9. ADDTIME(time1, time2): 将两个时间相加。
10. SUBTIME(time1, time2): 从一个时间中减去另一个时间。
除了上述函数外,MySQL还提供了许多其他日期和时间函数,
可以根据具体需求选择合适的函数进行操作。
这些函数可以在查询
中使用,也可以用于存储过程和触发器中。
通过灵活运用这些函数,我们可以轻松地处理日期和时间数据,满足各种业务需求。
总的来说,MySQL时间函数为我们提供了强大的工具,能够帮
助我们在数据库中进行高效的日期和时间处理。
希望这些信息能够
对你有所帮助。
sql函数写法
sql函数写法
SQL函数是一组预定义的程序代码,可完成特定的任务。
SQL支持许多内置函数,如数学函数、字符串函数、日期函数等等。
函数通过其名称和传递它们的参数来调用。
下面是一些常见的SQL函数的写法:
1. 数学函数:
- ABS():返回一个数的绝对值。
- CEILING():返回一个数最小的整数,大于或等于该数。
- FLOOR():返回一个数最大的整数,小于或等于该数。
- ROUND():将一个数四舍五入到指定的小数位数。
2. 字符串函数:
- CONCAT():连接两个或多个字符串。
- LEFT():返回一个字符串的左侧指定数量的字符。
- RIGHT():返回一个字符串的右侧指定数量的字符。
- LENGTH():返回一个字符串的长度。
3. 日期函数:
- CURDATE():返回当前日期。
- YEAR():返回一个日期值中的年份。
- MONTH():返回一个日期值中的月份。
- DAY():返回一个日期值中的日。
SQL函数的语法格式通常为函数名(参数值)。
参数值可以是常量值、字段名、表达式或其他SQL函数的结果。
函数的返回值可以用于其他SQL语句的操作。
SQLServer日期函数及日期转换数据类型
SQLServer⽇期函数及⽇期转换数据类型⼀、统计语句1、--统计当前【>当天00点以后的数据】SELECT * FROM 表 WHERE CONVERT(Nvarchar, dateandtime, 111) = CONVERT(Nvarchar, GETDATE(), 111) ORDER BY dateandtime DESC2、--统计本周SELECT * FROM 表 WHERE datediff(week,[dateadd],getdate())=03、--统计本⽉SELECT * FROM 表 WHERE datediff(month,[dateadd],getdate())=04、统计当前SELECT * FROM 表 WHERE datediff(day,[dateadd],getdate())=0Select * From table with(nolock) Where Convert(varchar(10),[CreateTime],120) = Convert(varchar(10),getDate(),120)⼆、时间函数1、当前系统⽇期、时间select getdate()2、dateadd 在向指定⽇期加上⼀段时间的基础上,返回新的 datetime 值,例如:向⽇期加上2天select dateadd(day,2,'2004-10-15') --返回:2004-10-17 00:00:00.0003、datediff 返回跨两个指定⽇期的⽇期和时间边界数select datediff(day,'2004-09-01','2004-09-18') --返回:174、datepart 返回代表指定⽇期的指定⽇期部分的整数SELECT DATEPART(month, '2004-10-15') --返回 105、datename 返回代表指定⽇期的指定⽇期部分的字符串SELECT datename(weekday, '2004-10-15') --返回:星期五6、day(), month(),year() --可以与datepart对照⼀下select 当前⽇期=convert(varchar(10),getdate(),120),select 当前时间=convert(varchar(8),getdate(),114),select datename(dw,'2004-10-15')select 本年第多少周=datename(week,'2004-10-15'),select 今天是周⼏=datename(weekday,'2004-10-15')7、求相差天数select datediff(day,'2004-01-01',getdate())8、⼀个⽉第⼀天的SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)9、本周的星期⼀SELECT DATEADD(wk, DATEDIFF(wk,0,getdate()), 0)select dateadd(wk,datediff(wk,0,getdate()),6)10、⼀年的第⼀天SELECT DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)11、季度的第⼀天SELECT DATEADD(qq, DATEDIFF(qq,0,getdate()), 0)12、当天的半夜SELECT DATEADD(dd, DATEDIFF(dd,0,getdate()), 0)13、上个⽉的最后⼀天SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))14、去年的最后⼀天SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))15、本⽉的最后⼀天SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0))16、本年的最后⼀天SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0))17、本⽉的第⼀个星期⼀select DATEADD(wk, DATEDIFF(wk,0,dateadd(dd,6-datepart(day,getdate()),getdate())), 0) 18、查询本周注册⼈数select count(*) from [user]where datediff(week,create_day-1,getdate())=019、上周注册⼈数select count(*) from [user]where datediff(week,create_day-1,getdate())=120、本⽉注册⼈数select count(*) from [user]where datediff(month,create_day,getdate())=021、上⽉注册⼈数select count(*) from [user]where datediff(month,create_day,getdate())=1如果要效率,⽤⼀下⽅式22、查询本周注册⼈数select count(*) from [user]where create_day>=dateadd(day,2-datepart(weekday,getdate()),convert(varchar,getdate(),112)) and create_day<dateadd(day,9-datepart(weekday,getdate()),convert(varchar,getdate(),112)) 23、上周注册⼈数select count(*) from [user]where create_day>=dateadd(day,-5-datepart(weekday,getdate()),convert(varchar,getdate(),112)) and create_day<dateadd(day,2-datepart(weekday,getdate()),convert(varchar,getdate(),112)) 24、本⽉注册⼈数select count(*) from [user]where create_day>=dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))and create_day<dateadd(month,1,dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))) 25、上⽉注册⼈数select count(*) from [user]where create_day>=dateadd(month,-1,dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))) and create_day<dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))26、本周select count(*) from Userwhere datediff(dd,create_day,getdate()) <= datepart(dw,getdate())27、上周select count(*) from Userwhere datediff(dd,create_day,(getdate() - datepart(dw,getdate()))) <= 728、本⽉select count(*) from Userwhere datepart(mm,create_day) = datepart(mm,getdate())29、上⽉select count(*) from Userwhere datepart(mm,create_day) = datepart(mm,getdate()) - 130、本周注册⼈数select count(*) from [User]where datediff(dd,create_day,getdate()) <= datepart(dw,getdate())31、上周注册⼈数select count(*) from [User]where datediff(dd,create_day,(getdate() - datepart(dw,getdate()))) <= 732、本⽉注册⼈数select count(*) from [User]where datepart(mm,create_day) = datepart(mm,getdate())33、上⽉注册⼈数select count(*) from [User]where datepart(mm,create_day) = datepart(mm,getdate()) - 134、查询今⽇所有SELECT * from feedback WHERE (DATEDIFF(d,fedtime,GETDATE())=0) ORDER BY fedid DESC month(create_day)=month(getdate())本⽉month(create_day)=month(getdate())-1 上⽉今天的所有数据:select * from 表名 where DateDiff(dd,datetime类型字段,getdate())=0昨天的所有数据:select * from 表名 where DateDiff(dd,datetime类型字段,getdate())=17天内的所有数据:select * from 表名 where DateDiff(dd,datetime类型字段,getdate())<=730天内的所有数据:select * from 表名 where DateDiff(dd,datetime类型字段,getdate())<=30本⽉的所有数据:select * from 表名 where DateDiff(mm,datetime类型字段,getdate())=0本年的所有数据:select * from 表名 where DateDiff(yy,datetime类型字段,getdate())=0系统函数:系统函数函数参数/功能GetDate( )返回系统⽬前的⽇期与时间DateDiff (interval,date1,date2)以interval 指定的⽅式,返回date2 与date1两个⽇期之间的差值 date2-date1DateAdd (interval,number,date)以interval指定的⽅式,加上number之后的⽇期DatePart (interval,date)返回⽇期date中,interval指定部分所对应的整数值DateName (interval,date)返回⽇期date中,interval指定部分所对应的字符串名称参数 interval的设定值:值缩写(Sql Server)Access 和 ASP说明Year Yy yyyy年 1753 ~ 9999Quarter Qq q季 1 ~ 4Month Mm m⽉1 ~ 12Day of yearDy y⼀年的⽇数,⼀年中的第⼏⽇ 1-366Day Dd d⽇,1-31Weekday Dw w⼀周的⽇数,⼀周中的第⼏⽇ 1-7Week Wk ww周,⼀年中的第⼏周 0 ~ 51Hour Hh h时0 ~ 23Minute Mi n分钟0 ~ 59Second Ss s秒 0 ~ 59Millisecond Ms-毫秒 0 ~ 999access 和 asp 中⽤date()和now()取得系统⽇期时间;其中DateDiff,DateAdd,DatePart也同是能⽤于Access和asp中,这些函数的⽤法也类似举例:1.GetDate() ⽤于sql server :select GetDate()2.DateDiff('s','2005-07-20','2005-7-25 22:56:32')返回值为 514592 秒DateDiff('d','2005-07-20','2005-7-25 22:56:32')返回值为 5 天3.DatePart('w','2005-7-25 22:56:32')返回值为 2 即星期⼀(周⽇为1,周六为7)DatePart('d','2005-7-25 22:56:32')返回值为 25即25号DatePart('y','2005-7-25 22:56:32')返回值为 206即这⼀年中第206天DatePart('yyyy','2005-7-25 22:56:32')返回值为 2005即2005年Sql 取当天或当⽉的记录表中的时间格式是这样的:2007-02-02 16:50:08.050, 如果直接和当天的时间⽐较,就总得不到准确数据,但是我们可以把这种格式的时间[格式化]成 2007-02-02,也就是只有年-⽉-⽇,然后把当天的时间也格式化成年-⽉-⽇的格式.这样,思路就出来了!我们格式化⽇期要⽤到 Convert()这个函数,要⽤到3个参数,⾸先来格式化当天的⽇期,Convert(varchar(10),getDate(),120)这样我们就可以把当天的⽇期格式化为: 2007-2-2,然后格式化数据库表中的⽇期Convert(varchar(10),TimeFiled,120),最后我们就可以⽤⼀条Sql语句得到当天的数据了.例如:转⾃⽹络程序代码Select * From VIEW_CountBill Where Convert(varchar(10),[time],120) = Convert(varchar(10),getDate(),120)注意:Convert()函数中的各个参数的意义,第⼀个参数,varchar(10)是⽬标系统所提供的数据类型,包括 bigint 和 sql_variant。
sql日期函数
sql日期函数SQL数据库中常用的日期函数有很多,可以用来处理和操作日期和时间相关的数据。
下面列举了一些常见的日期函数并进行了详细解释。
1.NOW(函数:返回当前日期和时间。
例如:SELECTNOW(;2.DATE(函数:提取日期部分,即返回日期的年、月、日部分。
例如:SELECTDATE('2024-12-31');3.EXTRACT(函数:提取日期或时间的特定部分,如年、月、日、小时、分钟、秒等。
例如:SELECTEXTRACT(YEARFROM'2024-12-31');4.DATE_ADD(函数:在一个日期上添加指定的时间间隔。
例如:SELECTDATE_ADD('2024-12-31',INTERVAL1YEAR);5.DATE_SUB(函数:在一个日期上减去指定的时间间隔。
例如:SELECTDATE_SUB('2024-12-31',INTERVAL1YEAR);6.DATEDIFF(函数:计算两个日期之间的天数差。
例如:SELECTDATEDIFF('2024-12-31','2024-01-01');7.TIMEDIFF(函数:计算两个时间之间的时间差。
例如:SELECTTIMEDIFF('23:59:59','00:00:00');8.DATE_FORMAT(函数:将日期或时间进行格式化。
例如:SELECTDATE_FORMAT('2024-12-31','%Y年%m月%d日');9.DAYOFWEEK(函数:返回指定日期是星期几。
例如:SELECTDAYOFWEEK('2024-12-31');10.MONTH(函数:返回指定日期的月份。
例如:SELECTMONTH('2024-12-31');11.YEAR(函数:返回指定日期的年份。
sql sysdate函数用法
sql sysdate函数用法
`SYSDATE` 是 SQL 中用于获取当前日期和时间的函数。
这个函数在不同的数据库系统中可能有不同的行为和语法,所以具体的用法可能会因数据库而异。
以下是一些常见的数据库系统中 `SYSDATE` 的用法:
1. Oracle:
```sql
SELECT SYSDATE FROM dual;
```
在 Oracle 中,`SYSDATE` 返回服务器的当前日期和时间。
2. SQL Server:
```sql
SELECT GETDATE();
```
在 SQL Server 中,可以使用 `GETDATE()` 函数来获取当前日期和时间。
3. MySQL:
```sql
SELECT NOW();
```
在 MySQL 中,可以使用 `NOW()` 函数来获取当前日期和时间。
4. PostgreSQL:
```sql
SELECT CURRENT_TIMESTAMP;
```
在 PostgreSQL 中,可以使用 `CURRENT_TIMESTAMP` 来获取当前日期和时间。
5. SQLite:
```sql
SELECT datetime('now');
```
在 SQLite 中,可以使用 `datetime('now')` 来获取当前日期和时间。
注意:在某些数据库系统中,`SYSDATE` 可能返回的是服务器的系统时间,而不是客户端的时间。
所以,如果你想要获取客户端的当前时间,你可能需要使用其他的函数或方法。
sql日期时间函数+格式转换
sql⽇期时间函数+格式转换<⽇期时间函数>(可参考下列表格)转换函数to_date() 作⽤将字符类型按⼀定格式转化为⽇期类型:具体⽤法:to_date(‘2004-11-27’,’yyyy-mm-dd’),前者为字符串,后者为转换⽇期格式,注意,前后两者要以⼀对应。
如;to_date(‘2004-11-27 13:34:43’, ‘yyyy-mm-dd hh24:mi:ss’)多种⽇期格式:YYYY:四位表⽰的年份YYY,YY,Y:年份的最后三位、两位或⼀位,缺省为当前世纪MM:01~12的⽉份编号MONTH:九个字符表⽰的⽉份,右边⽤空格填补MON:三位字符的⽉份缩写WW:⼀年中的星期D:星期中的第⼏天DD:⽉份中的第⼏天DDD:年所中的第⼏天DAY:九个字符表⽰的天的全称,右边⽤空格补齐HH,HH12:⼀天中的第⼏个⼩时,12进制表⽰法HH24:⼀天中的第⼏个⼩时,取值为00~23MI:⼀⼩时中的分钟SS:⼀分钟中的秒SSSS:从午夜开始过去的秒数to_char():将⽇期转按⼀定格式换成字符类型SQL> select to_char(sysdate,’yyyy-mm-dd hh24:mi:ss’) time from dual;1、常⽤⽇期⽅法(1)DATENAME ( datepart ,date )返回表⽰指定⽇期的指定⽇期部分的字符串。
SELECT DateName(day,Getdate()) –返回1(2)DATEPART ( datepart , date )返回表⽰指定⽇期的指定⽇期部分的整数。
SELECT DATEPART(year,Getdate()) –返回2016(3)DATEADD (datepart , number, date )返回给指定⽇期加上⼀个时间间隔后的新datetime 值。
SELECT DATEADD(week,1,GetDate()) –当前⽇期加⼀周后的⽇期(4)DATEDIFF ( datepart , startdate , enddate )返回跨两个指定⽇期的⽇期边界数和时间边界数。
sqlserverdate函数
sqlserverdate函数SQL Server中有多个与日期相关的函数和运算符,用于处理日期和时间数据。
下面是一些常用的SQL Server日期函数。
1.GETDATE(:返回当前日期和时间。
2.SYSDATETIME(:返回当前日期和时间,包括毫秒。
3.DATEPART(:用于从日期和时间表达式中提取指定的日期部分,如年、月、日、小时、分钟等。
4.DATEADD(:用于在给定的日期上增加或减少指定的时间间隔,如年、月、日、小时、分钟等。
例如:SELECT DATEADD(YEAR, 1, GETDATE() AS NextYear;--返回当前日期加上一年后的结果。
5.DATEDIFF(:用于计算两个日期之间的差距,返回的结果可以是年、月、日、小时、分钟等。
例如:SELECT DATEDIFF(DAY, '2024-01-01', GETDATE() AS DaysPassed;--返回从特定日期到当前日期的天数。
6.EOMONTH(:返回指定日期所在月份的最后一天。
例如:SELECT EOMONTH('2024-07-15') AS LastDayOfMonth;--返回指定日期所在月份的最后一天的日期。
7.FORMAT(:用于将日期和时间格式化为指定的格式。
例如:SELECT FORMAT(GETDATE(, 'yyyy/MM/dd HH:mm:ss') AS FormattedDate;--返回当前日期和时间的指定格式。
8.CAST(:用于将一个数据类型转换为另一个数据类型,包括日期和时间类型。
例如:SELECT CAST('2024-07-15' AS DATETIME) AS DateValue;--将字符串转换为日期类型。
9.CONVERT(:与CAST(函数类似,用于将一个数据类型转换为另一个数据类型,包括日期和时间类型。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
现在给出一些实践后的用法:
1、上月末天:
SQL> select to_char(add_months(last_day(sysdate),-1),'yyyy-MM-dd') LastDay from dual;
相信很多人都有过统计某些数据的经历,比如,要统计财务的情况,可能要按每年,每季度,每月,甚至每个星期来分别统计、那在oracle中应该怎么来写sql语句呢,这个时候Oracle的日期函数会给我们很多帮助、
得到时刻秒 24小时
select to_char(current_date, 'yyyy/MM/DD hh24:mi:ss') as Day from dual
where to_char(t.d, 'MM') = to_char(sysdate, 'MM') --找出当前月份的周五的日期
and trim(to_char(t.d, 'Day')) = '星期五'
--------
03-05-02
03-05-09
03-05-16
03-05-23
TO_C
----
2005
8.要找到某月中所有周五的具体日期
select to_char(t.d,'YY-MM-DD') from (
select trunc(sysdate, 'MM')+rownum-1 as d
from dba_objects
where rownum < 32) t
DDD 当年第几, 1月1日为001,2月1日为032 Select to_char(sysdate,’DDD’) from dual; 363 2002年1 2月2 9日为第363天
DD 当月第几天 Select to_char(sysdate,’DD’) from dual; 04 10月4日为第4天
-4.6966741
5、NEXT_DAY(d, day_of_week)
返回由"day_of_week"命名的,在变量"d"指定的日期之后的第一个工作日的日期、参数"day_of_week"必须为该星期中的某一天、
SQL> SELECT next_day(to_date('20050620','YYYYMMDD'),1) FROM dual;
HH24 24小时制 Select to_char(sysdate,’HH24’) from dual; 14 下午2点08分为14
MI 分钟数(0~59) Select to_char(sysdate,’MI’) from dual; 17下午4点17分
SS 秒数(0~59) Select to_char(sysdate,’SS’) from dual; 22 11点3分22秒
03-05-30
如果把where to_char(t.d, 'MM') = to_char(sysdate, 'MM')改成sysdate-90,即为查找当前月份的前三个月中的每周五的日期、
LASTDAY
----------
2005-05-31
2、上月今天
SQL> select to_char(add_months(sysdate,-1),'yyyy-MM-dd') PreToday from dual;
PRETODAY
----------
2005-05-21
Month 用9个字符长度表示的月份名 Select to_char(sysdate,’Month’) from dual; May后跟6个空格表示5月
WW 当年第几周 Select to_char(sysdate,’WW’) from dual; 24表示2002年6月13日为第24周
W 本月第几周 Select to_char(sysdate,’W’) from dual; 2002年10月1日为第1周
SQL> select months_between(sysdate,to_date('2005-11-12','yyyy-mm-dd'))from dual;
MONTHS_BETWEEN(SYSDATE,TO_DATE('2005-11-12','YYYY-MM-DD'))
----------------------------------------------------------
--------------- ------------------------------------
-11:00 12-11月-03 04.59.13.668000 下午 -11:00
7、current_timesБайду номын сангаасamp()以timestamp with time zone数据类型返回当前会话时区中的当前日期
date_value:=current_date
SQL> column sessiontimezone for a15
SQL> select sessiontimezone,current_date from dual;
SESSIONTIMEZONE CURRENT_DA
--------------- ----------
----------
21-6月 -05
2、Last_day 本月最后一天
SQL> Select last_day(sysdate) from dual;
LAST_DAY(S
----------
30-6月 -05
3、Add_months(d,n) 当前日期d后推n个月
用于从一个日期值增加或减少一些月份
3.上月首天
SQL> select to_char(add_months(last_day(sysdate)+1,-2),'yyyy-MM-dd') firstDay from dual;
select to_char(add_months(sysdate,-1),'yyyy/MM/')||'01' as firstDay from dual
NEXT_DAY(T
----------
26-6月 -05
--◎ 时间点d开始,下一个星期几的日期
--◎ 星期日 = 1 星期一 = 2 星期二 = 3
-- 星期三 = 4 星期四 = 5 星期五 = 6 星期六 = 7
6、current_date()返回当前会话时区中的当前日期
SQL> select current_timestamp from dual;
CURRENT_TIMESTAMP
---------------------------------------------------------------------------
21-6月 -05 10.13.08.220589 上午 +08:00
NEXT_DAY(d,number)
--◎ 时间点d开始,下一个星期几的日期
--◎ 星期日 = 1 星期一 = 2 星期二 = 3
-- 星期三 = 4 星期四 = 5 星期五 = 6 星期六 = 7
oracle
SQL里常用的时间函数,经典推荐
FIRSTDAY
----------
2005-05-01
4.按照每周进行统计
SQL> select to_char(sysdate,'ww') from dual group by to_char(sysdate,'ww');
TO
--
25
5、按照每月进行统计
SQL> select to_char(sysdate,'mm') from dual group by to_char(sysdate,'mm');
Years
----------
2008
10、localtimestamp()返回会话中的日期和时间
SQL> select localtimestamp from dual;
LOCALTIMESTAMP
---------------------------------------------------------------------------
得到时刻秒 12小时
select to_char(current_date, 'yyyy/MM/DD hh:mi:ss') as Day from dual
常用日期型函数
1、Sysdate 当前日期和时间
SQL> Select sysdate from dual;
SYSDATE
date_value:=add_months(date_value,number_of_months)
SQL> Select add_months(sysdate,2) from dual;
ADD_MONTHS
----------
21-8月 -05
4、Months_between(f,s) 日期f和s间相差月数