[转]DB2时间类函数

Src URL:http://www.cnblogs.com/wanghonghu/archive/2012/05/25/2518604.html

1、db2可以通过SYSIBM.SYSDUMMY1、SYSIBM.DUAL获取寄存器中的值,也可以通过VALUES关键字获取寄存器中的值。

SELECT ‘HELLO DB2‘ FROM SYSIBM.SYSDUMMY1;--HELLO DB2
SELECT ‘HELLO DB2‘ FROM SYSIBM.DUAL;--HELLO DB2
VALUES ‘HELLO DB2‘;--HELLO DB2

2、CURRENT DATE获取当前日期;CURRENT TIME获取当前时间;CURRENT TIMESTAMP获取当前时间戳(含年、月、日、时、分、秒)。

VALUES CURRENT DATE--2012/5/25 0:00:00;
VALUES CURRENT TIME--20:48:53;
VALUES CURRENT TIMESTAMP--2012/5/25 20:49:12;

3、YEAR()获取年;MONTH()获取月;DAY()获取日;
     HOUR()获取小时;MINUTE()获取分钟;SECOND()获取秒;
     DATE()获取日期;TIME()获取时间;TIMESTAMP()获取时间戳。
     以上函数参数可以是日期时间类型,也可以为日期时间格式的字符串。

VALUES YEAR(CURRENT TIMESTAMP);/*2012*/  VALUES YEAR(‘2012-05-25 21:18:12‘);/*2012*/
VALUES MONTH(CURRENT TIMESTAMP);/*5*/  VALUES MONTH(‘2012-05-25 21:18:12‘);/*5*/
VALUES DAY(CURRENT TIMESTAMP);/*25*/  VALUES DAY(‘2012-05-25 21:18:12‘);/*25*/
VALUES HOUR(CURRENT TIMESTAMP);/*21*/  VALUES HOUR(‘2012-05-25 21:18:12‘);/*21*/
VALUES MINUTE(CURRENT TIMESTAMP);/*18*/  VALUES MINUTE(‘2012-05-25 21:18:12‘);/*18*/
VALUES SECOND(CURRENT TIMESTAMP);/*12*/   VALUES SECOND(‘2012-05-25 21:18:12‘);/*12*/
VALUES DATE(CURRENT TIMESTAMP);/*2012/5/25 0:00:00*/  VALUES DATE(‘2012-05-25 21:18:12‘);/*2012/5/25 0:00:00*/
VALUES TIME(CURRENT TIMESTAMP);/*21:18:12*/  VALUES TIME(‘2012-05-25 21:18:12‘);/*21:18:12*/
VALUES TIMESTAMP(CURRENT TIMESTAMP);/*2012/5/25 21:18:12*/  VALUES TIMESTAMP(‘2012-05-25 21:18:12‘);/*2012/5/25 21:18:12*/

4、db2时间可以直接加减带单位的时间长度。

VALUES TIMESTAMP(‘2012-5-25 21:18:12‘)+1 YEAR;--2013/5/25 21:18:12
VALUES TIMESTAMP(‘2012-5-25 21:18:12‘)+1 MONTH;--2012/6/25 21:18:12
VALUES TIMESTAMP(‘2012-5-25 21:18:12‘)+1 DAY;--2012/5/26 21:18:12
VALUES TIMESTAMP(‘2012-5-25 21:18:12‘)+1 HOUR;--2012/5/25 22:18:12
VALUES TIMESTAMP(‘2012-5-25 21:18:12‘)+1 MINUTE;--2012/5/25 21:19:12
VALUES TIMESTAMP(‘2012-5-25 21:18:12‘)+1 SECOND;--2012/5/25 21:18:13
VALUES TIMESTAMP(‘2012-5-25 21:18:12‘)+1 YEAR+1 MONTH+1 DAY+1 HOUR+1 MINUTE +1 SECOND ;--2013/6/26 22:19:13
VALUES TIMESTAMP(‘2012-5-25 21:18:12‘)-1 YEAR-1 MONTH-1 DAY-1 HOUR-1 MINUTE -1 SECOND ;--2011/4/24 20:17:11

5、通过days()可以获取两个时间相差天数。

VALUES DAYS(CURRENT DATE)-DAYS(CURRENT DATE-1000 DAY);--1000 

6、TO_CHAR()把时间转换成指定格式的字符串类型(db2较低版本不支持)。
     “YYYY-MM-DD HH:MI:SS” 十二小时制;“YYYY-MM-DD HH24:MI:SS” 二十四小时制。
     (“YYYY-MM-DD hh:mm:ss”不会报错,但是mm值取的是月的值。)

SELECT TO_CHAR(TIMESTAMP(‘2012-5-25 21:18:12‘),‘YYYY-MM-DD‘) FROM SYSIBM.DUAL;--2012-05-25
SELECT TO_CHAR(TIMESTAMP(‘2012-5-25 21:18:12‘),‘YYYY-MM-DD HH:MI:SS‘) FROM SYSIBM.DUAL;--2012-05-25 09:18:12
SELECT TO_CHAR(TIMESTAMP(‘2012-5-25 21:18:12‘),‘YYYY-MM-DD HH24:MI:SS‘) FROM SYSIBM.DUAL;--2012-05-25 21:18:12
(SELECT TO_CHAR(TIMESTAMP(‘2012-5-25 21:18:12‘),‘YYYY-MM-DD HH24:MM:SS‘) FROM SYSIBM.DUAL;--2012-05-25 21:05:12)

7、DAYNAME()返回指定日期的星期名,该星期名是由首字符大写、其他字符小写组成的英文名。

values DAYNAME(current timestamp)--Friday(当天为星期五)

8、DAYOFWEEK()返回参数中的星期几,用范围在 1-7 的整数值表示,其中 1 代表星期日。

values DAYOFWEEK(current timestamp);--6(当天为星期五)

9、DAYOFWEEK_ISO()返回参数中的星期几,用范围在 1-7 的整数值表示,其中 1 代表星期一。

values DAYOFWEEK_ISO(current timestamp);--5(当前为星期五)

10、DAYOFYEAR()返回参数中一年中的第几天,用范围在 1-366 的整数值表示。

values DAYOFYEAR(DATE(‘2012-02-01‘));--32

11、MONTHNAME()对于参数的月部分的月份,返回一个大小写混合的字符串(例如,January)。

values MONTHNAME(CURRENT TIMESTAMP);--May(当前为五月)

12、WEEK()返回参数中一年的第几周,用范围在 1-54 的整数值表示。以星期日作为一周的开始。(参数可以为日期格式或者日期格式的字符串)

VALUES WEEK(‘2012-05-25‘)--21

13、TIMESTAMPDIFF(n,CHAR(TIMESTAMP(‘2012-05-25 10:23:24‘)-TIMESTAMP(‘2012-05-25 10:20:24‘)))根据两个时间戳记之间的时差,返回由第一个参数定义的类型表示的估计时差。(整除部分,不会四舍五入)

n=2:秒 ; n=4 :分; n=8:时;

n=16 :天; n=32 :周;n=64:月;

n=128 :季度; n=256:年;

VALUES TIMESTAMPDIFF(2,CHAR(TIMESTAMP(‘2012-05-25 10:23:24‘)-TIMESTAMP(‘2012-05-25 10:20:24‘)));--180秒
VALUES TIMESTAMPDIFF(4,CHAR(TIMESTAMP(‘2012-05-25 12:23:24‘)-TIMESTAMP(‘2012-05-25 10:20:22‘)));--123分钟
VALUES TIMESTAMPDIFF(8,CHAR(TIMESTAMP(‘2012-05-25 12:23:24‘)-TIMESTAMP(‘2012-05-25 10:20:22‘)));--2小时
VALUES TIMESTAMPDIFF(16,CHAR(TIMESTAMP(‘2012-07-25 12:23:24‘)-TIMESTAMP(‘2012-05-25 10:20:22‘)));--60天
VALUES TIMESTAMPDIFF(32,CHAR(TIMESTAMP(‘2012-07-25 12:23:24‘)-TIMESTAMP(‘2012-05-25 10:20:22‘)));--8周
VALUES TIMESTAMPDIFF(64,CHAR(TIMESTAMP(‘2012-07-25 12:23:24‘)-TIMESTAMP(‘2012-05-25 10:20:22‘)));--2月
VALUES TIMESTAMPDIFF(128,CHAR(TIMESTAMP(‘2012-08-25 10:20:22‘)-TIMESTAMP(‘2012-05-25 10:20:22‘)));--1季度
VALUES TIMESTAMPDIFF(256,CHAR(TIMESTAMP(‘2013-05-25 10:20:22‘)-TIMESTAMP(‘2012-05-25 10:20:22‘)));--1年

14、时期的格式。ISO,使用国际标准组织(ISO)制订的日期和时间格式;USA,使用美国日期和时间的 IBM 标准格式。

values char(current date,iso)--2012-05-25
values char(current date,usa)--05/25/2012
values char(current time,iso)--23.21.32
时间: 2024-11-13 22:43:30

[转]DB2时间类函数的相关文章

DB2时间函数大全

DB2时间函数是我们最常见的函数之一,下面就为您介绍一些DB2时间函数,供您参考,希望可以让您对DB2时间函数有更多的了解. 1 --获取当前日期: 2 3 select current date from sysibm.sysdummy1; 4 values current date; 5 6 --获取当前日期 7 select current time from sysibm.sysdummy1; 8 values current time; 9 --获取当前时间戳 10 select cu

DB2时间操作

以下内容选编自<DB2 基础: 日期和时间的使用> 1.使用SQL获取数据库服务器当前时间戳 SELECT current date FROM sysibm.sysdummy1 SELECT current time FROM sysibm.sysdummy1 SELECT current timestamp FROM sysibm.sysdummy1 说明:sysibm.sysdummy1表是一个特殊的内存中的表,用它可以显示如上面演示的 DB2 寄存器的值.这里,current date.

db2时间函数

获取当前日期: select current date from sysibm.sysdummy1; values current date; --获取当前时间 select current time from sysibm.sysdummy1; values current time; --获取当前时间戳 select current timestamp from sysibm.sysdummy1; values current timestamp; --要使当前时间或当前时间戳记调整到 GM

js 时间类函数

js 时间类是  Date() var currtime = new Date();// 实例一个时间,是当前时间 获取时间的各部分的方法如下: .getYear()  两位数的年份 .getFullYear() 四位数年份 .getMonth()  月分 0-11,如果按1-12月算,应该加1  [ getMonth()+1 ] .getDate()  几号 .getDay()  星期几 0-6 0是星期日, .getTime() 从1970年1月1日开始到现在的毫秒数 .getHours()

DB2日期和时间函数汇总

上一篇提到过在DB2中,可以通过SYSIBM.SYSDUMMY1.SYSIBM.DUAL获取寄存器中的值,也可以通过VALUES关键字获取寄存器中的值.则在这篇中,我们直接用VALUES关键字来看看这些函数. 1.CURRENT DATE获取当前日期:CURRENT TIME获取当前时间:CURRENT TIMESTAMP获取当前时间戳(含年.月.日.时.分.秒):YEAR()获取年:MONTH()获取月:DAY()获取日: HOUR()获取小时:MINUTE()获取分钟:SECOND()获取秒

DB2日期与时间

摘选自:http://www.cnblogs.com/wanghonghu/archive/2012/05/25/2518604.html 1.db2可以通过SYSIBM.SYSDUMMY1.SYSIBM.DUAL获取寄存器中的值,也可以通过VALUES关键字获取寄存器中的值. SELECT 'HELLO DB2' FROM SYSIBM.SYSDUMMY1;--HELLO DB2 SELECT 'HELLO DB2' FROM SYSIBM.DUAL;--HELLO DB2 VALUES 'H

DB2——db2日期和时间常用汇总

1.db2可以通过SYSIBM.SYSDUMMY1.SYSIBM.DUAL获取寄存器中的值,也可以通过VALUES关键字获取寄存器中的值. SELECT 'HELLO DB2' FROM SYSIBM.SYSDUMMY1;--HELLO DB2 SELECT 'HELLO DB2' FROM SYSIBM.DUAL;--HELLO DB2 VALUES 'HELLO DB2';--HELLO DB2 2.CURRENT DATE获取当前日期:CURRENT TIME获取当前时间:CURRENT

ORACLE-DB2-SQLSERVER-MYSQL 数据库 时间转换 查询表结构

ORACLE: --时间转字符串 TO_CHAR(SYSDATE,'YYYYMMDDHH24MISS') --字符串转时间 select  TO_DATE('20140701125751','YYYYMMDDHH24MISS') from dual  -- 2014-07-01 12:57:51 --查询table SELECT * FROM ALL_TABLES WHERE TABLE_NAME ='{0}' --查询column SELECT aa.table_name           

db2命令

创建数据库 db2 create db GZH db2 -td; -vf D:\db2sql\GZH db2 [email protected] -vf D:\db2sql\proc.sql 检查vsftp rpm -qa|grep vsftpd 启动vsftp /etc/rc.d/init.d/vsftpd start 查询gcc命令 gcc -v 创建节点名称 su - db2inst1 db2 catalog tcpid node db2node remote IP server 5000