内容发布更新时间 : 2025/1/6 16:56:57星期一 下面是文章的全部内容请认真阅读。
DB2中有关日期和时间的函数,及应用
DAYNAME 返回一个大小写混合的字符串,对于参数的日部分,用星期表示这一天的名称(例如,Friday)。
DAYOFWEEK 返回参数中的星期几,用范围在 1-7 的整数值表示,其中 1 代表星期日。 DAYOFWEEK_ISO 返回参数中的星期几,用范围在 1-7 的整数值表示,其中 1 代表星期一。
DAYOFYEAR 返回参数中一年中的第几天,用范围在 1-366 的整数值表示。 DAYS 返回日期的整数表示。
JULIAN_DAY 返回从公元前 4712 年 1 月 1 日(儒略日历的开始日期)到参数中指定日期值之间的天数,用整数值表示。
MIDNIGHT_SECONDS 返回午夜和参数中指定的时间值之间的秒数,用范围在 0 到 86400 之间的整数值表示。
MONTHNAME 对于参数的月部分的月份,返回一个大小写混合的字符串(例如,January)。
TIMESTAMP_ISO 根据日期、时间或时间戳记参数而返回一个时间戳记值。 TIMESTAMP_FORMAT 从已使用字符模板解释的字符串返回时间戳记。
TIMESTAMPDIFF 根据两个时间戳记之间的时差,返回由第一个参数定义的类型表示的估计时差。
TO_CHAR 返回已用字符模板进行格式化的时间戳记的字符表示。TO_CHAR 是 VARCHAR_FORMAT 的同义词。
TO_DATE 从已使用字符模板解释过的字符串返回时间戳记。TO_DATE 是 TIMESTAMP_FORMAT 的同义词。
WEEK 返回参数中一年的第几周,用范围在 1-54 的整数值表示。以星期日作为一周的开始。
WEEK_ISO 返回参数中一年的第几周,用范围在 1-53 的整数值表示。
要使当前时间或当前时间戳记调整到 GMT/CUT,则把当前的时间或时间戳记减去当前时区寄存器:
current time - current timezone
current timestamp - current timezone
给定了日期、时间或时间戳记,则使用适当的函数可以单独抽取出(如果适用的话)年、月、日、时、分、秒及微秒各部分:
YEAR (current timestamp) MONTH (current timestamp) DAY (current timestamp) HOUR (current timestamp) MINUTE (current timestamp) SECOND (current timestamp)
MICROSECOND (current timestamp)
因为没有更好的术语,所以您还可以使用英语来执行日期和时间计算: current date + 1 YEAR
current date + 3 YEARS + 2 MONTHS + 15 DAYS
current time + 5 HOURS - 3 MINUTES + 10 SECONDS
从时间戳记单独抽取出日期和时间也非常简单:
DATE (current timestamp) TIME (current timestamp)
而以下示例描述了如何获得微秒部分归零的当前时间戳记:
CURRENT TIMESTAMP - MICROSECOND (current timestamp) MICROSECONDS
如果想将日期或时间值与其它文本相衔接,那么需要先将该值转换成字符串。为此,只要使用 CHAR() 函数:
char(current date) char(current time)
char(current date + 12 hours)
要将字符串转换成日期或时间值,可以使用:
TIMESTAMP ('2002-10-20-12.00.00.000000') TIMESTAMP ('2002-10-20 12:00:00') DATE ('2002-10-20') DATE ('10/20/2002') TIME ('12:00:00') TIME ('12.00.00')
TIMESTAMP()、DATE() 和 TIME() 函数接受更多种格式。上面几种格式只是示例,我将把它作为一个练习,让读者自己去发现其它格式。
有时,您需要知道两个时间戳记之间的时差。为此,DB2 提供了一个名为 TIMESTAMPDIFF() 的内置函数。但该函数返回的是近似值,因为它不考虑闰年,而且假设每个月只有 30 天。以下示例描述了如何得到两个日期的近似时差:
timestampdiff (
timestamp('2002-11-30-00.00.00')- timestamp('2002-11-08-00.00.00')))
对于
1 = 秒的小数部分 2 = 秒 4 = 分 8 = 时 16 = 天
32 = 周 64 = 月 128 = 季度 256 = 年
当日期很接近时使用 timestampdiff() 比日期相差很大时精确。如果需要进行更精确的计算,可以使用以下方法来确定时差(按秒计):
(DAYS(t1) - DAYS(t2)) * 86400 +
(MIDNIGHT_SECONDS(t1) - MIDNIGHT_SECONDS(t2))
为方便起见,还可以对上面的方法创建 SQL 用户定义的函数:
CREATE FUNCTION secondsdiff(t1 TIMESTAMP, t2 TIMESTAMP) RETURNS INT RETURN (
(DAYS(t1) - DAYS(t2)) * 86400 +
(MIDNIGHT_SECONDS(t1) - MIDNIGHT_SECONDS(t2)) ) @
如果需要确定给定年份是否是闰年,以下是一个很有用的 SQL 函数,您可以创建它来确定给定年份的天数:
CREATE FUNCTION daysinyear(yr INT) RETURNS INT
RETURN (CASE (mod(yr, 400)) WHEN 0 THEN 366 ELSE CASE (mod(yr, 4)) WHEN 0 THEN
CASE (mod(yr, 100)) WHEN 0 THEN 365 ELSE 366 END ELSE 365 END END)@
最后,以下是一张用于日期操作的内置函数表。它旨在帮助您快速确定可能满足您要求的函数,但未提供完整的参考。有关这些函数的更多信息,请参考 SQL 参考大全。
SQL 日期和时间函数
DAYNAME 返回一个大小写混合的字符串,对于参数的日部分,用星期表示这一天的名称(例如,Friday)。
DAYOFWEEK 返回参数中的星期几,用范围在 1-7 的整数值表示,其中 1 代表星期日。 DAYOFWEEK_ISO 返回参数中的星期几,用范围在 1-7 的整数值表示,其中 1 代表星期一。
DAYOFYEAR 返回参数中一年中的第几天,用范围在 1-366 的整数值表示。 DAYS 返回日期的整数表示。
JULIAN_DAY 返回从公元前 4712 年 1 月 1 日(儒略日历的开始日期)到参数中指定日期值之间的天数,用整数值表示。
MIDNIGHT_SECONDS 返回午夜和参数中指定的时间值之间的秒数,用范围在 0 到 86400 之间的整数值表示。
MONTHNAME 对于参数的月部分的月份,返回一个大小写混合的字符串(例如,January)。 TIMESTAMP_ISO 根据日期、时间或时间戳记参数而返回一个时间戳记值。 TIMESTAMP_FORMAT 从已使用字符模板解释的字符串返回时间戳记。 TIMESTAMPDIFF 根据两个时间戳记之间的时差,返回由第一个参数定义的类型表示的估计时差。
TO_CHAR 返回已用字符模板进行格式化的时间戳记的字符表示。TO_CHAR 是 VARCHAR_FORMAT 的同义词。
TO_DATE 从已使用字符模板解释过的字符串返回时间戳记。TO_DATE 是 TIMESTAMP_FORMAT 的同义词。
WEEK 返回参数中一年的第几周,用范围在 1-54 的整数值表示。以星期日作为一周的开始。
××××××××××××××××××××××××××××××××××××××××××××××× DB2常用标量函数 函数名 说明
AVG() 返回一组数值的平均值 VAR(), 返回一组数值的方差
ASCII() 返回整数参数最左边的字符的ASCII码
BIGINT() 返回整型常量中的数字或字符串的64位整数表示
CHAR() 返回日期时间型,字符串,整数,十进制或双精度浮点数的字符串表示 CHR() 返回具有由参数指定的ASCII码的字符 CONCAT(str1,str2) 返回两个字符串的连接 YEAR() 返回数值的年部分 UCASE() 返回字符串的大写 TIME() 返回一个数值中的时间
SUBSTR(EXP1,EXP2) 返回EXP1串自EXP2处开始的子串 SECOND() 返回一个数值的秒部分 RTRIM() 删除字符串尾部的空格
ROUND(EXP1,EXP2) 返回EXP1小数点右边的第EXP2位置处开始的四舍五入值 REPLACE(EXP1,EXP2,EXP3) 用EXP3替代EXP1中所有的EXP2 REAL() 返回一个数值的单精度浮点数表示 RAND() 返回0和1之间的随机浮点数
POSSTR(EXP1,EXP2) 返回EXP2在EXP1中的位置 MONTH() 返回一个数值的月部分
MOD(EXP1,EXP2) 返回EXP1除以EXP2的余数 MINUTE() 返回一个数值的分钟部分 LTRIM() 删除字符串前面的空格 HOUR() 返回一个数值的小时部分
××××××××××××××××××××××××××××××××××××××××××××××××××××××
DB2中的限制之三字符串的限制
在現實的DB2應用中大家可能經常會遇到一些錯誤,錯誤的原因是對DB2的
限制不太了解而引起的,在此我簡單地總結一下,歡迎大家繼續﹐以便和大家共享﹐ 共同探討﹐共同近步﹗(以下主要以DB2 7.X為例)。 1. CHAR 的最大長度(字節數)<=254
2. VARCHAR 的最大長度(字節數)<=32672
3. LONG VARCHAR 的最大長度(字節數)<=32700 4. CLOB 的最大長度(字節數)<=2147483647 5. GRAPHICCHAR 的最大長度(字節數)<=127 6. VARGRAPHIC 的最大長度(字節數)<=16336
7. LONG VARGRAPHIC 的最大長度(字節數)<=16350 8. DBCLOB 的最大長度(字節數)<=1073741823 9. BLOB 的最大長度(字節數)<=2147483647 10. 字符常量的最大長度(字節數)<=32672 11. 圖形常量的最大長度(字節數)<=16336
12. 串聯字符串的最大長度(字節數)<=2147483647 13. 串聯圖形串的最大長度(字節數)<=1073741823 14. 串聯二進制串的最大長度(字節數)<=2147483647 15. 十六進制常量數字的最大長度(字節數)<=16336 16. 分類注釋的最大長度(字節數)<=254
17. 運行時結构類型列對象的最大長度(字節數)<=1
×××××××××××××××××××××××××××××××××××××××××××× IBM DB2 日常维护汇总
1.DB2 产品的级别有那些 ?
企业版的 NTERPRISEEDITION 工作组版 WORKGROUPEDITION
企业扩展版 ENTERPRISEEXTENDEDEDITION 个人版的 PERSONALEDITION 卫星版的 SATELLITEEDITION 微型版的 EVERYPLACE
2. 可以连接到 DB2 数据库的产品有哪些 ? DB2 客户端
DB2CONNECT
DB2DATAPROPAGATOR DB2NET.DATA DB2DATAJOINER
DB2RELATIONALCONNECT WEBSPHERE 应用服务器 等