SQL日期格式大全
sql中date的格式

sql中date的格式
在SQL中,日期(date)通常以特定的格式进行表示。
不同的数据库管理系统(DBMS)可能具有不同的日期格式,但以下是一些常见的日期格式示例:
1.YYYY-MM-DD:这是最常见的日期格式之一,其中YYYY表示年份,
MM表示月份,DD表示日期。
例如,"2023-07-19"。
2.MM/DD/YYYY:这种格式在某些数据库系统中较为常见,其中MM
表示月份,DD表示日期,YYYY表示年份。
例如,"07/19/2023"。
3.YY-MM-DD:这种格式与第一种格式类似,但年份以两位数表示。
例如,"23-07-19"。
4.YYYYMMDD:这种格式将年份、月份和日期合并为一个整体。
例
如,"20230719"。
请注意,这些只是常见的日期格式示例,具体的日期格式可能会因使用的数据库管理系统而有所不同。
在特定的数据库中,您可能需要根据该系统的要求来指定日期的格式。
一些常用查询SQL语句以及显示格式

⼀些常⽤查询SQL语句以及显⽰格式1.查询当前年、⽉、周相关时间1.1.查询当前年份SELECT TO_CHAR(SYSDATE,'YYYY') AS YEAR FROM DUAL--查询当前年份SELECT TO_CHAR(SYSDATE,'YYY') AS YEAR FROM DUAL--查询当前年份后两位SELECT TO_CHAR(SYSDATE,'YY') AS YEAR FROM DUAL--查询当前年份最后两位SELECT TO_CHAR(SYSDATE,'Y') AS YEAR FROM DUAL--查询当前年份最后⼀位1.2.查询当前年份第⼏天SELECT TO_CHAR(SYSDATE,'DDD') AS DAYS FROM DUAL1.3.查询当前⽉份第⼏天SELECT TO_CHAR(SYSDATE,'DD') AS DAYS FROM DUAL1.4.查询当前周的星期⼏SELECT TO_CHAR(SYSDATE,'dy') AS WEEK FROM DUALSELECT TO_CHAR(SYSDATE,'day') AS WEEK FROM DUAL1.5.查询当前年的第⼏天:SELECT TO_CHAR(SYSDATE,'DDD') AS DAYS FROM DUAL2.查询当前第⼏季度SELECT TO_CHAR(SYSDATE,'Q') AS JD FROM DUAL年内是第⼏周查询当前在⼀年内是第⼏周3.查询当前在⼀SELECT TO_CHAR(SYSDATE,'IW') AS WEEKNUM FROM DUALSELECT TO_CHAR(SYSDATE,'WW') AS WEEKNUM FROM DUALSELECT TO_CHAR(SYSDATE,'W') AS WEEKNUM FROM DUAL4.查询当前某年某⽉有多少天SELECT TO_CHAR(last_day(to_date('2019/02/01','YYYY/MM/DD')),'DD') AS MONTH_DAYS_NUMBER FROM DUAL5.查询当前的⽇期格式SELECT TO_CHAR(SYSDATE,'YYYY/MM/DD') AS MONTH FROM DUAL--获取当前⽇期的'YYYY/MM/DD'格式:2020/01/02SELECT TO_CHAR(SYSDATE,'YYYYMMDD') AS MONTH FROM DUAL--获取当前⽇期的'YYYYMMDD'格式:20200102SELECT TO_CHAR(SYSDATE,'YYYYMMDD HH:MI:SS') AS now FROM DUAL--获取当前时间,精确到秒的12⼩时制格式:20200102 03:18:25SELECT TO_CHAR(SYSDATE,'YYYYMMDD HH24:MI:SS') AS now FROM DUAL--获取当前时间,精确到秒24⼩时制的格式:20200102 15:18:13SELECT TO_CHAR(SYSDATE,'YYYY/MM/DD HH24:MI:SS:PM:DY') AS now FROM DUAL--获取当前时间的格式,显⽰上、下午和星期⼏:2020/01/02 15:17:59:下午:星期四6.查询距离当前时间⼀段时间间隔的时间,当前时间之前⽤“-”当前时间之后⽤“+”SELECT TO_CHAR(SYSDATE, 'YYYY/MM/DD HH24:MI:SS') AS NOW,TO_CHAR(SYSDATE - INTERVAL '7' second,'YYYY/MM/DD HH24:MI:SS') AS PAST FROM DUAL --查询当前时间的7秒前时间SELECT TO_CHAR(SYSDATE, 'YYYY/MM/DD HH24:MI:SS') AS NOW,TO_CHAR(SYSDATE - INTERVAL '7' minute,'YYYY/MM/DD HH24:MI:SS') AS PAST FROM DUAL --查询当前时间的7分钟前时间SELECT TO_CHAR(SYSDATE, 'YYYY/MM/DD HH24:MI:SS') AS NOW,TO_CHAR(SYSDATE - INTERVAL '7'hour ,'YYYY/MM/DD HH24:MI:SS') AS PAST FROM DUAL --查询当前时间的7⼩时前时间SELECT TO_CHAR(SYSDATE, 'YYYY/MM/DD HH24:MI:SS') AS NOW,TO_CHAR(SYSDATE - INTERVAL '7'day ,'YYYY/MM/DD HH24:MI:SS') AS PAST FROM DUAL --查询当前时间的7天前时间SELECT TO_CHAR(SYSDATE, 'YYYY/MM/DD HH24:MI:SS') AS NOW,TO_CHAR(SYSDATE - INTERVAL '7'month ,'YYYY/MM/DD HH24:MI:SS') AS PAST FROM DUAL --查询当前时间的7⽉前时间SELECT TO_CHAR(SYSDATE, 'YYYY/MM/DD HH24:MI:SS') AS NOW,TO_CHAR(SYSDATE - INTERVAL '7'year ,'YYYY/MM/DD HH24:MI:SS') AS PAST FROM DUAL --查询当前时间的7年前时间SELECT TO_CHAR(SYSDATE, 'YYYY/MM/DD HH24:MI:SS') AS NOW,TO_CHAR(SYSDATE -8*INTERVAL '7'hour ,'YYYY/MM/DD HH24:MI:SS') AS PAST FROM DUAL --查询当前时间参数年、⽉、⽇、时、分、秒乘以⼀个数字倍数之前的时。
sql时间格式转换大全

Sqlserver中经常要操作一些时间类型的字段转换,我又不太记得住,所以搜集了以下的一些SqlserverConvert DateTime相关的资料发表在自己的小站里,方便自己以后要用的时候寻找,望对大家也有帮助.将sqlserver中table表的[datetime]字段值‘2007-11-07 16:41:35.033’ 改为‘2007-11-07 00:00:00‘去除了时分秒.[datetime]字段要为datetime类型的哦.UPDATE table SET [datetime]= Convert(char(11),[datetime],120)获取当前日期利用convert来转换成我们需要的datetime格式.select CONVERT(varchar(12) , getdate(), 112 )20040912------------------------------------------------------------select CONVERT(varchar(12) , getdate(), 102 )2004.09.12------------------------------------------------------------select CONVERT(varchar(12) , getdate(), 101 )09/12/2004------------------------------------------------------------select CONVERT(varchar(12) , getdate(), 103 )12/09/2004------------------------------------------------------------select CONVERT(varchar(12) , getdate(), 104 )12.09.2004------------------------------------------------------------select CONVERT(varchar(12) , getdate(), 105 )12-09-2004------------------------------------------------------------select CONVERT(varchar(12) , getdate(), 106 )12 09 2004------------------------------------------------------------select CONVERT(varchar(12) , getdate(), 107 )09 12, 2004------------------------------------------------------------select CONVERT(varchar(12) , getdate(), 108 )11:06:08------------------------------------------------------------select CONVERT(varchar(12) , getdate(), 109 )09 12 2004 1------------------------------------------------------------select CONVERT(varchar(12) , getdate(), 110 )09-12-2004------------------------------------------------------------select CONVERT(varchar(12) , getdate(), 113 )12 09 2004 1------------------------------------------------------------select CONVERT(varchar(12) , getdate(), 114 )11:06:08.177------------------------------------------------------------declare @dateTime DateTime--定义一个datetime的变量set @dateTime=getdate();--获取系统当前时间,并赋值给@dateTime字段--短日期格式:yyyy-m-dSELECT REPLACE(CONVERT(varchar(10),@dateTime,120),N'-0','-')--长日期格式:yyyy年mm月dd日SELECT STUFF(STUFF(CONVERT(char(8),@dateTime,112),5,0,N'年'),8,0,N'月')+N'日'--长日期格式:yyyy年m月d日SELECT DATENAME(Year,@dateTime)+N'年'+CAST(DATEPART(Month,@dateTime) AS varchar)+N'月'+DATENAME(Day,@dateTime)+N'日'--完整日期+时间格式:yyyy-mm-dd hh:mi:ss:mmmSELECT CONVERT(char(11),@dateTime,120)+CONVERT(char(12),@dateTime,114)------------------------------------------------------------------------------------------------2、日期推算处理DECLARE @dt datetimeSET @dt=GETDATE()DECLARE @number intSET @number=3--1.指定日期该年的第一天或最后一天--A. 年的第一天SELECT CONVERT(char(5),@dt,120)+'1-1'--B. 年的最后一天SELECT CONVERT(char(5),@dt,120)+'12-31'--2.指定日期所在季度的第一天或最后一天--A. 季度的第一天SELECT CONVERT(datetime,CONVERT(char(8),DATEADD(Month,DATEPART(Quarter,@dt)*3-Month(@dt)-2,@dt),120)+'1')--B. 季度的最后一天(CASE判断法)SELECT CONVERT(datetime,CONVERT(char(8),DATEADD(Month,DATEPART(Quarter,@dt)*3-Month(@dt),@dt),120)+CASE WHEN DATEPART(Quarter,@dt) in(1,4)THEN '31'ELSE '30' END)--C. 季度的最后一天(直接推算法)SELECT DATEADD(Day,-1,CONVERT(char(8),DATEADD(Month,1+DATEPART(Quarter,@dt)*3-Month(@dt),@dt),120)+'1')--3.指定日期所在月份的第一天或最后一天--A. 月的第一天SELECT CONVERT(datetime,CONVERT(char(8),@dt,120)+'1')--B. 月的最后一天SELECT DATEADD(Day,-1,CONVERT(char(8),DATEADD(Month,1,@dt),120)+'1') --C. 月的最后一天(容易使用的错误方法)SELECT DATEADD(Month,1,DATEADD(Day,-DAY(@dt),@dt))--4.指定日期所在周的任意一天SELECT DATEADD(Day,@number-DATEPART(Weekday,@dt),@dt)--5.指定日期所在周的任意星期几--A. 星期天做为一周的第1天SELECTDATEADD(Day,@number-(DATEPART(Weekday,@dt)+@@DATEFIRST-1)%7,@dt) --B. 星期一做为一周的第1天SELECTDATEADD(Day,@number-(DATEPART(Weekday,@dt)+@@DATEFIRST-2)%7-1,@d t)转自:/fengfage/blog/item/1429fda1b9ec3d9b46106453.html。
SQL 中使用CONVERT转日期格式

将某种数据类型的表达式显式转换为另一种数据类型。
由于某些需求经常用到取日期格式的不同.现以下可在SQL Server中将日期格式化.SQL Server 支持使用科威特算法的阿拉伯样式中的数据格式。
在表中,左侧的两列表示将datetime 或smalldatetime 转换为字符数据的style 值。
给style 值加100,可获得包括世纪数位的四位年份(yyyy)。
不带世纪数位(yy) 带世纪数位(yyyy)标准输入/输出**- 0 或100 (*) 默认值mon dd yyyy hh:miAM(或PM)1 101 美国mm/dd/yyyy2 102 ANSI yy.mm.dd3 103 英国/法国dd/mm/yy4 104 德国dd.mm.yy5 105 意大利dd-mm-yy6 106 - dd mon yy7 107 - mon dd, yy8 108 - hh:mm:ss- 9 或109 (*) 默认值+ 毫秒mon dd yyyy hh:mi:ss:mmmAM(或PM)10 110 美国mm-dd-yy11 111 日本yy/mm/dd12 112 ISO yymmdd- 13 或113 (*) 欧洲默认值+ 毫秒dd mon yyyy hh:mm:ss:mmm(24h)14 114 - hh:mi:ss:mmm(24h)- 20 或120 (*) ODBC 规范yyyy-mm-dd hh:mm:ss[.fff]- 21 或121 (*) ODBC 规范(带毫秒)yyyy-mm-dd hh:mm:ss[.fff]- 126(***) ISO8601 yyyy-mm-dd Thh:mm:ss:mmm(不含空格)- 130* 科威特dd mon yyyy hh:mi:ss:mmmAM- 131* 科威特dd/mm/yy hh:mi:ss:mmmAM* 默认值(style 0 或100、9 或109、13 或113、20 或120、21 或121)始终返回世纪数位(yyyy)。
OracleSQL日期及日期格式获取命令

OracleSQL⽇期及⽇期格式获取命令⽇期及⽇期格式:获取⽇期:sysdate()格式化⽇期to_char(sysdate(),'yyyy-mm-dd,hh24:mi:ss')to_date(sysdate(),'yyyy-mm-dd,hh24:mi:ss')注:to_char 把⽇期或数字转换为字符串to_char(number, '格式')to_char(salary, '$99,999.99')to_char(date, '格式')to_date 把字符串转换为中的⽇期类型to_date(char, '格式')转换格式:表⽰ year 的:y 表⽰年的最后⼀位yy 表⽰年的最后2位yyy 表⽰年的最后3位yyyy ⽤4位数表⽰年表⽰ month 的:mm ⽤2位数字表⽰⽉mon ⽤简写形式,⽐如11⽉或者novmonth ⽤全称,⽐如11⽉或者november表⽰ day 的:dd 表⽰当⽉第⼏天ddd 表⽰当年第⼏天dy 当周第⼏天,简写,⽐如星期五或者friday 当周第⼏天,全称,⽐如星期五或者friday表⽰ hour 的:hh 2位数表⽰⼩时 12进制hh24 2位数表⽰⼩时 24⼩时表⽰minute的:mi 2位数表⽰分钟表⽰second的:ss 2位数表⽰秒 60进制表⽰季度的:q ⼀位数表⽰季度(1-4)另外还有ww ⽤来表⽰当年第⼏周 w⽤来表⽰当⽉第⼏周。
24⼩时制下的时间范围:00:00:00-23:59:5912⼩时制下的时间范围:1:00:00-12:59:59例⼦:返回系统⽇期: 2018/1/19 22:44:54select sysdate from dual;格式化: 2018-01-19 22:46:59select to_char(sysdate,'yy-mm-dd hh24:mi:ss') from dual获取昨天:2018/1/18select trunc(sysdate-1) from dual;获取上个⽉第⼀天:2017/12/1select add_months(trunc(sysdate,'MON'),-1) from dualselect add_months(trunc(sysdate,'MON'),-13) from dual获得本季度第⼀天:2018/1/1select trunc(add_months(sysdate,0),'Q') from dual获得上季度第⼀天:2017/10/1select trunc(add_months(sysdate,-3),'Q') from dual补充当前时间减去7分钟的时间select sysdate,sysdate - interval '7' MINUTE from dual;当前时间减去7⼩时的时间select sysdate - interval '7' hour from dual;当前时间减去7天的时间select sysdate - interval '7'day from dual;当前时间减去7⽉的时间select sysdate,sysdate - interval '7'month from dual;当前时间减去7年的时间select sysdate,sysdate - interval '7'year from dual;时间间隔乘以⼀个数字select sysdate,sysdate -8*interval '7' hour from dual;Oracle 常⽤的时间函数Sysdate :当前⽇期和时间SQL>Select sysdate from dual;2018/1/1923:15:20Last_day :本⽉最后⼀天SQL>Select last_day(sysdate) from dual;2018/1/3123:16:24Add_months(d,n) :当前⽇期d后推n个⽉,⽤于从⼀个⽇期值增加或减少⼀些⽉份SQL>Select add_months(sysdate,2) from dual;2018/3/1923:18:29Months_between(f,s) :⽇期f和s间相差⽉数SQL>select months_between(sysdate,to_date('2017-8-1','yyyy-mm-dd'))from dual;5.6120034348865NEXTDAY(d, dayofweek) :返回由"dayofweek"命名的,在变量"d"指定的⽇期之后的第⼀个⼯作⽇的⽇期。
sql的日期和时间函数–date_format

sql的⽇期和时间函数–date_format Mysql的⽇期和时间函数–date_formatDATE_FORMAT(date,format)依照 format 字符串格式化 date 值。
下⾯的修饰符可被⽤于 format 字符串中:修饰符含义%M ⽉的名字 (January..December)%W 星期的名字 (Sunday..Saturday)%D 有英⽂后缀的某⽉的第⼏天 (0th, 1st, 2nd, 3rd, etc.)%Y 年份,数字的,4 位%y 年份,数字的,2 位%X 周值的年份,星期⽇是⼀个星期的第⼀天,数字的,4 位,与 ‘%V’ ⼀同使⽤%x 周值的年份,星期⼀是⼀个星期的第⼀天,数字的,4 位,与 ‘%v’ ⼀同使⽤%a 缩写的星期名 (Sun..Sat)%d ⽉份中的天数,数字的 (00..31)%e ⽉份中的天数,数字的 (0..31)%m ⽉,数字的 (00..12)%c ⽉,数字的 (0..12)%b 缩写的⽉份名 (Jan..Dec)%j ⼀年中的天数 (001..366)%H ⼩时 (00..23)%k ⼩时 (0..23)%h ⼩时 (01..12)%I ⼩时 (01..12)%l ⼩时 (1..12)%i 分钟,数字的 (00..59)%r 时间,12 ⼩时 (hh:mm:ss [AP]M)%T 时间,24 ⼩时 (hh:mm:ss)%S 秒 (00..59)%s 秒 (00..59)%p AM 或 PM%w ⼀周中的天数 (0=Sunday..6=Saturday)%U 星期 (00..53),星期⽇是⼀个星期的第⼀天%u 星期 (00..53),星期⼀是⼀个星期的第⼀天%V 星期 (01..53),星期⽇是⼀个星期的第⼀天。
与 ‘%X’ ⼀起使⽤%v 星期 (01..53),星期⼀是⼀个星期的第⼀天。
与 ‘%x’ ⼀起使⽤%% ⼀个字母 “%”所有其它的字符不经过解释,直接复制到结果中sql> SELECT DATE_FORMAT(’1997-10-04 22:23:00′, ‘%W %M %Y’);-> ‘Saturday October 1997′mysql> SELECT DATE_FORMAT(’1997-10-04 22:23:00′, ‘%H:%i:%s’);-> ‘22:23:00′mysql> SELECT DATE_FORMAT(’1997-10-04 22:23:00′,‘%D %y %a %d %m %b %j’);-> ‘4th 97 Sat 04 10 Oct 277′。
sql日期格式

关键字: sqlserver 日期, 字符串格式转换SELECT convert(char,你的日期字段,120) as date2 FROM table mssql默认以系统时间格式输出,你可以调整系统的时间格式来解决当然是在程序里解决比较灵活,convert(char,date,N)输出的各中样式N 日期样式0 04 2 2005 9:06AM1 04/02/052 05.04.023 02/04/054 02.04.055 02-04-056 02 04 057 04 02, 058 09:06:189 04 2 2005 9:06:18:857AM10 04-02-0511 05/04/0212 05040213 02 04 2005 09:06:18:85714 09:06:18:85720 2005-04-02 09:06:1821 2005-04-02 09:06:18.85722 04/02/05 9:06:18 AM23 2005-04-0224 09:06:1825 2005-04-02 09:06:18.857100 04 2 2005 9:06AM101 04/02/2005102 2005.04.02103 02/04/2005104 02.04.2005105 02-04-2005106 02 04 2005107 04 02, 2005108 09:06:18109 04 2 2005 9:06:18:857AM110 04-02-2005111 2005/04/02112 20050402113 02 04 2005 09:06:18:857114 09:06:18:857120 2005-04-02 09:06:18121 2005-04-02 09:06:18.857126 2005-04-02T09:06:18.857sql to_char 日期转换字符串2009-04-27 12:241、转换函数与date操作关系最大的就是两个转换函数:to_date(),to_char()to_date() 作用将字符类型按一定格式转化为日期类型:具体用法:to_date('2004-11-27','yyyy-mm-dd'),前者为字符串,后者为转换日期格式,注意,前后两者要以一对应。
SQLSERVER时间格式大全

SQLSERVER时间格式⼤全具体的⽹址倒是没保存,可是我这个⼈习惯把好的代码记起⽅法保存下来,现在贴出来,希望原作者体谅。
复制代码代码如下:---上个⽉⽉初第⼀天select CONVERT(varchar(12) , DATEADD(mm,DATEDIFF(mm,0,dateadd(mm,-1,getdate())),0), 112 )---上个⽉⽉末最后⼀天select CONVERT(varchar(12),dateadd(ms,-3,DATEADD(mm,DATEDIFF(m,0,getdate()),0)), 112 )--1. 显⽰本⽉第⼀天SELECT DATEADD(mm,DATEDIFF(mm,0,getdate()),0)select convert(datetime,convert(varchar(8),getdate(),120)+'01',120)--2. 显⽰本⽉最后⼀天select dateadd(day,-1,convert(datetime,convert(varchar(8),dateadd(month,1,getdate()),120)+'01',120))SELECT dateadd(ms,-3,DATEADD(mm,DATEDIFF(m,0,getdate())+1,0))--3. 上个⽉的最后⼀天SELECT dateadd(ms,-3,DATEADD(mm,DATEDIFF(mm,0,getdate()),0))--4. 本⽉的第⼀个星期⼀select DATEADD(wk,DATEDIFF(wk,0, dateadd(dd,6-datepart(day,getdate()),getdate())),0)--5. 本年的第⼀天SELECT DATEADD(yy,DATEDIFF(yy,0,getdate()),0)--6. 本年的最后⼀天SELECT dateadd(ms,-3,DATEADD(yy,DATEDIFF(yy,0,getdate())+1,0))--7. 去年的最后⼀天SELECT dateadd(ms,-3,DATEADD(yy,DATEDIFF(yy,0,getdate()),0))--8. 本季度的第⼀天SELECT DATEADD(qq,DATEDIFF(qq,0,getdate()),0)--9. 本周的星期⼀SELECT DATEADD(wk,DATEDIFF(wk,0,getdate()),0)--10. 查询本⽉的记录select * from tableName where DATEPART(mm, theDate)=DATEPART(mm, GETDATE()) and DATEPART(yy, theDate) = DATEPART(yy, GETDATE())--11. 查询本周的记录select * from tableName where DATEPART(wk, theDate) = DATEPART(wk, GETDATE()) and DATEPART(yy, theDate) = DATEPART(yy, GETDATE())--12 查询本季的记录注:其中:GETDATE() 是获得系统时间的函数。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
SQL 日期格式大全在函数CONVERT()中你可以使用许多种不同风格的日期和时间格式。
0 Default mon dd yyyy hh:miAM1 USA mm/dd/yy2 ANSI yy.mm.dd3 British/French dd/mm/yy4 German dd.mm.yy5 Italian dd-mm-yy6 - dd mon yy7 - mon dd,yy8 - hh:mi:ss9 Default + milliseconds--mon dd yyyyhh:mi:ss:mmmAM(or )10 USA mm-dd-yy11 JAPAN yy/mm/dd12 ISO yymmdd13 Europe Default + milliseconds--dd mon yyyyhh:mi:ss:mmm(24h)14 - hh:mi:ss:mmm(24h)类型0,9,和13总是返回四位的年。
对其它类型,要显示世纪,把style值加上100。
类型13和14返回24小时时钟的时间。
类型0,7,和13返回的月份用三位字符表示(用Nov代表November)。
对表11.1中所列的每一种格式,你可以把类型值加上100来显示有世纪的年(例如,00年将显示为2000年)。
例如,要按日本标准显示日期,包括世纪,你应使用如下的语句:SELECT CONVERT(VARCHAR(30),GETDATE(),111)在这个例子中,函数CONVERT()把日期格式进行转换,显示为2001/11/30网友跟贴:1.日期格式样式,借以将datetime 或smalldatetime 数据转换为字符数据(nchar、nvarchar、char、varchar、nchar 或nvarchar 数据类型);或者字符串格式样式,借以将float、real、money 或s mallmoney 数据转换为字符数据(nchar、nvarchar、char、varchar、nchar 或nvarchar 数据类型)。
SQL Server 支持使用科威特算法的阿拉伯样式中的数据格式。
在表中,左侧的两列表示将datetime 或smalldatetime 转换为字符数据的style 值。
给styl e 值加100,可获得包括世纪数位的四位年份(yyyy)。
不带世纪数位(yy) 带世纪数位(yyyy) 标准输入/输出**- 0 或100 (*) 默认值mon dd yyyy hh:miAM(或PM)1 101 美国mm/dd/ yyyy2 102 ANSI yy.m m.dd3 103 英国/法国dd/mm/yy4 104 德国dd.m m.yy5 105 意大利dd-mm-yy6 106 - dd mon yy7 107 - mon dd, yy8 108 - hh:mm:ss- 9 或109 (*) 默认值+ 毫秒mon dd yyyy hh:mi:ss:mmmAM(或PM)10 110 美国mm-dd-yy11 111 日本yy/ mm/dd12 112 ISO yymm dd- 13 或113 (*) 欧洲默认值+ 毫秒dd mon yyyy hh:mm: ss:mmm(24h)14 114 - hh:mi:ss:mmm(24h)- 20 或120 (*) ODBC 规范yyyy-mm-dd hh:mm:s s[.fff]- 21 或121 (*) ODBC 规范(带毫秒)yyyy-mm-dd hh:mm:ss[.fff]- 126(***) ISO8601 yyyy-mm-dd Thh:mm:ss:mmm(不含空格)- 130* 科威特dd mon yyyy hh:mi:ss:mmmAM- 131* 科威特dd/mm/yy hh:mi:ss:mmmAM2.日期函数//1.生肖(年份参数:int ls_year 返回参数:string):mid(fill('鼠牛虎兔龙蛇马羊猴鸡狗猪',48),(mod(ls_year -1900,12)+13)*2 -1,2)//2.天干地支(年份参数:int ls_year 返回参数:string):mid(fill('甲乙丙丁戊己庚辛壬癸',40),(mod(ls_year -1924,10)+11)*2 -1,2)+mid(fill('子丑寅卯辰巳午未申酉戌亥',48),(mod(ls_year -1924,12)+13)*2 -1,2)//3.星座(日期参数:date ls_date 返回参数:string):mid("摩羯水瓶双鱼白羊金牛双子巨蟹狮子处女天秤天蝎射手摩羯",(month(ls_date)+sign(sign(day(ls_ date) -(19+integer(mid('102123444423',month(ls_date),1))))+1))*4 -3,4)+'座'//4.判断闰年(年份参数:int ls_year 返回参数:int 0=平年,1=闰年):abs(sign(mod(sign(mod(abs(ls_year),4))+sign(mod(abs(ls_year),100))+sign(mod(abs(ls_year),40 0)),2)) -1)//5.某月天数(日期参数:date ls_date 返回参数:int):integer(28+integer(mid('3'+string(abs(sign(mod(sign(mod(abs(year(ls_date)),4))+sign(mod(abs (year(ls_date)),100))+sign(mod(abs(year(ls_date)),400)),2)) -1))+'3232332323',month(ls_dat e),1)))//6.某月最后一天日期(日期参数:date ls_date 返回参数:date):date(year(ls_date),month(ls_date),integer(28+integer(mid('3'+string(abs(sign(mod(sign(mod(ab s(year(ls_date)),4))+sign(mod(abs(year(ls_date)),100))+sign(mod(abs(year(ls_date)),400)), 2)) -1))+'3232332323',month(ls_date),1))))//7.另一个求某月最后一天日期(日期参数:date ls_date 返回参数:date):a.RelativeDate (date(year(ls_date)+sign(month(ls_date) -12)+1,mod(month(ls_date)+1,13)+abs(s ign(mod(month(ls_date)+1,13)) -1),1),-1)b.RelativeDate(date(year(ls_date)+integer(month(ls_date)/12),mod(month(ls_date),12)+1,1),-1)//8.另一个求某月天数(日期参数:date ls_date 返回参数:int):a.day(RelativeDate (date(year(ls_date)+sign(month(ls_date) -12)+1,mod(month(ls_date)+1,13)+a bs(sign(mod(month(ls_date)+1,13)) -1),1),-1))b.day(RelativeDate(date(year(ls_date)+integer(month(ls_date)/12),mod(month(ls_date),12)+1,1),-1))//9.某月某日星期几--同PB系统函数DayName(日期参数:date ls_date 返回参数:string):'星期'+mid('日一二三四五六',(mod(year(ls_date) -1 + int((year(ls_date) -1)/4) - int((y ear(ls_date) -1)/100) + int((year(ls_date) -1)/400) + daysafter(date(year(ls_date),1, 1),ls_date)+1,7)+1)*2 -1,2)//10.求相隔若干月份后的相对日期(日期参数:date ls_date 相隔月份(可取负数):int ls_add_mon th 返回参数:date):date(year(ls_date)+int((month(ls_date)+ls_add_month)/13),long(mid(fill('01020304050607080910 1112',48),(mod(month(ls_date)+ls_add_month -1,12)+13)*2 -1,2)),day(ls_date) -integer(righ t(left(string(day(RelativeDate (date(year(ls_date)+int((month(ls_date)+ls_add_month)/13)+si gn(long(mid(fill('010203040506070809101112',48),(mod(month(ls_date)+ls_add_month -1,12)+13) *2 -1,2)) -12)+1,mod(long(mid(fill('010203040506070809101112',48),(mod(month(ls_date)+ls_a dd_month -1,12)+13)*2 -1,2))+1,13)+abs(sign(mod(long(mid(fill('010203040506070809101112',4 8),(mod(month(ls_date)+ls_add_month -1,12)+13)*2 -1,2))+1,13)) -1),1),-1)) -day(ls_date), '00')+'00000',5),3))/100)//11.求某日在当年所处的周数(日期参数:date ls_date 返回参数:int)://a.周始日为星期天//a1abs(int(-((daysafter( RelativeDate(date(year(ls_date),1,1), -mod(year(ls_date) -1 + int ((year(ls_date) -1)/4) - int((year(ls_date) -1)/100) + int((year(ls_date) -1)/400) + 1,7) +1),ls_date)+1)/7)))//a2(使用DayNumber函数)abs(int(-((daysafter( RelativeDate(date(year(ls_date),1,1), -DayNumber(date(year(ls_date), 1,1))+1),ls_date)+1)/7)))//b.周始日为星期一//b1abs(int(-((daysafter( RelativeDate(date(year(ls_date),1,1), -integer(mid('6012345',mod(yea r(ls_date) -1 + int((year(ls_date) -1)/4) - int((year(ls_date) -1)/100) + int((year (ls_date) -1)/400) + 1,7),1))),ls_date)+1)/7)))//b2(使用DayNumber函数)abs(int(-((daysafter( RelativeDate(date(year(ls_date),1,1), -integer(mid('6012345',DayNumb er(date(year(ls_date),1,1)),1))),ls_date)+1)/7)))//12.求某日相对于过去某一日期所处的周数(日期参数:date ls_date_1(要求的某日),ls_date_2(过去的某日) 返回参数:int)://注:ls_date_1>ls_date_2//a.周始日为星期天//a1abs(int(-((daysafter( RelativeDate(ls_date_2, -mod(year(ls_date_2) -1 + int((year(ls_da te_2) -1)/4) - int((year(ls_date_2) -1)/100) + int((year(ls_date_2) -1)/400) + days after(date(year(ls_date_2),1,1),ls_date_2)+ 1,7) +1),ls_date_1)+1)/7)))//a2(使用DayNumber函数)abs(int(-((daysafter( RelativeDate(ls_date_2, -DayNumber(ls_date_2)+1),ls_date_1)+1)/7)))//b.周始日为星期一//b1abs(int(-((daysafter( RelativeDate(ls_date_2, -integer(mid('6012345',mod(year(ls_date_2) -1 + int((year(ls_date_2) -1)/4) - int((year(ls_date_2) -1)/100) + int((year(ls_ date_2) -1)/400) + daysafter(date(year(ls_date_2),1,1),ls_date_2)+ 1,7) ,1))),ls_date_1) +1)/7)))//b2(使用DayNumber函数)abs(int(-((daysafter( RelativeDate(ls_date_2, -integer(mid('6012345',DayNumber(ls_date_2), 1))),ls_date_1)+1)/7)))。