今天在db2中查询数据时出现错误:
Overflow occurred during numeric data type conversion:SQLCODE=-413, SQLSTATE=22003, DRIVER=3.53.71
数字数据类型转换过程中出现溢出
select * from rpbbzd where to_number(BBZD_BEGIN) < 2018012004
and to_number(BBZD_END) >=2018012004
此sql在db210.5中没有问题,但是在8.2中会爆以上溢出错误。
改成:
select * from rpbbzd where cast(BBZD_BEGIN as INT) < 2018012004
and cast(BBZD_END as INT) >=2018012004
仍然会有错误,对比了一下数据发现超出int类型的范围了,改用bigint:
select * from rpbbzd where cast(BBZD_BEGIN as BIGINT) < 2018012004
and cast(BBZD_END as BIGINT) >=2018012004
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
DB2的常用数据类型包括以下几个:
一.数字型的。
1. SMALLINT ---短整型,范围为-32768~+32767
2. INT/INTEGER ---整型,4个字节,范围为-2147483648~+2147483647,一遍多用于做自动生成的序列,或者用作表记录的id使用。
3. BIGINT ----大整型,8个字节,精度为19位,够大了,一般较少使用。
4. DECIMAL(P,S) ---小数型,其中P为精度,S为小数位数,隐含小数点(小数点不计入位数)。比如M DECIMAL(5,2),那么就是指定M的精度为5位(除小数点外所有数字的位数不能超过5),否则插入时会发生数据位溢出;而小数的位数不能超过2,否则插入时会截断小数位。
比如:
M: 123.45(成功)
M:12.345(成功,但是截断为12.34)
M:1234.5(失败,整数位超标,溢出报错)
5. REAL ---单精度浮点型,不常用
6. DOUBLE ----双精度浮点型,不常用
二.字符型
char(n) ----定长字符串,长度范围1~254,常用
varchar(n) ----变长字符串,长度范围1~32672,常用
CLOB -----字符大对象字符串,很大,没用过,要用再研究。
三.时间型
date ----占4个字节 插入格式为 'YYYY-MM-DD'
time ----占3个字节 插入格式为 'HH:MM:SS'
timestamp ----占10个字节 插入格式为 'YYYY-MM-DD HH:MM:SS'
当然,这都是采用内部格式压缩过的。
四.空值
空值使用NULL表示,NULL可以表示任何数据类型的空值,但是NULL不能参加任何算数运算和逻辑运算,如果勉强运算得到的也是NULL
---------------------
作者:dlodj
来源:CSDN
原文:https://blog.csdn.net/DLODJ/article/details/7033619
版权声明:本文为博主原创文章,转载请附上博文链接!