数字

数据类型        精度          最小值                                        最大值                      


smallint         5              -32,768                                       32,767                      


integer          10            -2,147,483,648                            2,147,483,647                      


bigint            19            -9,223,372,036,854,775,808        9,223,372,036,854,775,807                      


decimal        31         

real               24            -3.402E+38                                  3.402E+38                      


double         53            -1.79769E+308                            +1.79769E+308

字符

数据类型            最大长度    

char                  254字节    

varchar            32672字节    

long varchar   32700字节    

clob                  2,147,483,647字节    

graphic            127字节    

vargraphic      16,336字节    

dbclob            1,073,741,823字节    

blob                 2,147,483,647字节

日期类型

描述                        限制            

最小date值            0001-01-01            

最大date值            9999-12-31            

最小time值            00:00:00            

最大time值            24:00:00            

最小timestamp值            0001-01-01-00.00.00.000000            

最大timestamp值            9999-12-31-24.00.00.000000

DB2提供有3种大对象:

    Binary Large Objects(BLOBs)

    Single-Byte Character Large Objects(CLOBs)

    Double-Byte Character Large Objects(DBCLOBs)

    lobs可以直接作为数据库对象在过程中使用

create procedure staffresume ( in p_empno char(6),out p_resume clob(1M) )

language sql

specific staffresume

begin

    select reume into p_resume

      from emp_resume

      where empno=p_empno and resume_format = ‘ascii’;

end

如何选择正确的数据类型:

问题            数据类型

字符数据是变长的?            varchar

字符数据是变长的,最大值是多少?            varchar

数据是否需要排序?            char,varchar, numeric

数据是否用于算术计算?            decimal,numeric,real,double,bigint,integer,smallint

数值包含小数吗?            decimal,numeric,real,double

数据是定长的?            char

数据是否有特殊的含义            用户自定义类型

数据很大,或者你需要存储非传统数据?            clob,blob,dbclob

tip:基于表的基本类型定义变量,数据类型装换会影响数据库的性能

1.创建

    create distinct type <distinct-type-name> as  <source-data-type> with comparisons

    其中with comparisons表示可以使用系统提供的比较符号;例如:

    create distinct type miles as double with comparisons;

注意:在自定义类型创建结束之后,DB2会自动创建两个类型转换函数

    miles   (double)

    double (miles)

    create distinct type kilometers as double with comparisons;    

2.定义变量

   declare v_in_mile     miles;

   declare v_in_kilometers    kilometers;

3.使用方法

      1)错误的使用方法,没有使用转换函数

             if (v_in_mile > v_in_kilometers)

             if (v_in_mile > 30.0)

      2)正确的使用方法

             if (v_in_mile > miles(double(v_in_kilometer)/1.6))

if (v_in_mile >miles(30.0))

日期、时间和字符串的操作:

日期和时间的操作

1)取时间相关的值

select current date                 from sysibm.sysdummy1;

select current time                from sysibm.sysdummy1;

select current timestamp             from sysibm.sysdummy1;

select year(current timestamp)         from sysibm.sysdummy1;

select month(current timestamp)         from sysibm.sysdummy1;

select day(current timestamp)         from sysibm.sysdummy1;

select hour(current timestamp)         from sysibm.sysdummy1;

select minute(current timestamp)         from sysibm.sysdummy1;

select second(current timestamp)         from sysibm.sysdummy1;

select microsecond(current timestamp)     from sysibm.sysdummy1;

2)计算

select current date + 1 year                  from sysibm.sysdummy1

select current date + 3 years + 2 months + 15 days      from sysibm.sysdummy1

select current time + 5 hours - 3 minutes + 10 seconds      from sysibm.sysdummy1

select days(current date) – days(date(‘2000-01-01’))      from sysibm.sysdummy1

3)转换成字符型    select char(current date)                from sysibm.sysdummy1;    select char(current time)                from sysibm.sysdummy1;

   select char(current time + 12 hours )            from sysibm.sysdummy1;

4)字符类型转换为日期或时间类型

  select timestamp(‘2002-10-20-12.00.00.000000’)    from sysibm.sysdummy1;

  select timestamp(‘2002-10-20 12.00.00’)        from sysibm.sysdummy1;

  select date(‘2002-10-20’)                from sysibm.sysdummy1;

  select date(‘10/20/2002’)                from sysibm.sysdummy1;

  select time(’12:00:00’)                from sysibm.sysdummy1;

  select time(’12.00.00’)                 from sysibm.sysdummy1;

字符串的操作

1)拼接

    select concat(‘abc’,’def’) from sysibm.sysdummy1;

    select ‘abc’||’def’             from sysibm.sysdummy1;     -- 多值时使用

2)大小写转换

     upper,lower

3)返回第一个非空的值

    select coalesce(c1,c2,’abc’) from t1

收藏于 2011-01-30
来自于百度空间

DB2数据类型(抄袭)的更多相关文章

  1. DB2数据类型

    DB2数据库的内置数据类型主要分成数值型(numeric).字符串型(character string).图形字符串(graphic string).二进制字符串型(binary string)或日期 ...

  2. db2 数据类型

    数据类型: 字符串类型 描述 CHARACTER(n) n bytes定长字符串. n 大于0 不大于255. 默认 1. VARCHAR(n) 变长字符串,最大 n bytes. n大于 0 小于表 ...

  3. Oracle VS DB2 数据类型

    =========================Oracle VS DB2==================================== 本文转自:http://www.bitscn.co ...

  4. DB2 Vs MySQL系列 | MySQL与DB2的数据类型对比

    随着MySQL数据库的应用越来越广泛,DB2向MySQL数据库的迁移需求也越来越多.进行数据库之间迁移的时候,首先遇到的并且也是最基本最重要的就是两种数据库数据类型之间的转换. 相关阅读: 从商用到开 ...

  5. DB2常用sql函数 (转载)

    http://www.techonthenet.com/sql/index.php 一.字符转换函数 1.ASCII() 返回字符表达式最左端字符的ASCII 码值.在ASCII()函数中,纯数字的字 ...

  6. Oracle的Numer类型与C,C#数据类型对应关系

    最近一直在编和Oracle数据库相关程序.Oracle的Number类型和C语言,C#语言类型的对应关系,在网络上查找很久,也没有找到说明文字.但在http://oracle.chinaitlab.c ...

  7. db2和oracle字段类型对比

    在网上找到一片关于oracle与DB2数据类型的比较,特记下来. Oracle DB2/400 Oracle数据类型 注意事项 DB2 UDB数据类型 注意事项 DATE DATETIMETIMEST ...

  8. 从商用到开源:15个维度,全面剖析DB2与MySQL数据库的差异

    随着MySQL数据库的应用越来越广泛,DB2向MySQL数据库的迁移需求也越来越多.进行数据库之间迁移的时候,首先遇到的并且也是最基本最重要的就是两种数据库数据类型之间的转换. 相关阅读: 从商用到开 ...

  9. DB2的sql函数

    转自:http://blog.chinaunix.net/uid-21162795-id-3587646.html 一.字符转换函数 1.ASCII() 返回字符表达式最左端字符的ASCII 码值.在 ...

随机推荐

  1. SpringMVC + Mybatis 多数据源配置

    比较常用的配置,多数据源.主从等等. 大概的逻辑是: 1.spring-mybatis.xml中配置多个数据源 2.使用Spring提供的AbstractRoutingDataSource类来根据请求 ...

  2. PowerDesigner 连接oracle数据库

    TNS Service Name 不是监听名称,填写这个格式就可以了 10.0.0.2:1521/orcl

  3. 怎样把代码复制到word中并保持颜色

  4. License 校验

    1:了解keytool 的一些命令  http://www.micmiu.com/lang/java/keytool-start-guide/ 本人在github找的一个demo:https://gi ...

  5. eclipse 创建注释模板

    使用  Alt+Shift+J 可以快速注释. 我们每次手动敲入作者,时间,版本等信息,有一些重复,可通过设置eclipse注释模板,减少工作量. Window -> preference -& ...

  6. visual stdio 工程 宏

    $(SolutionDir)  solution目录 $(ProjectDir) Project目录 $(TargetDir) 目标文件夹,如编译出的exe文件所在的目录 $(Configuratio ...

  7. numpy linspace arange函数

    linspace(start, end, num_of_points), 区间 [start, end],产生一个等差数列,差为:(end-start)/(num_of_point-1). arang ...

  8. 吴裕雄 数据挖掘与分析案例实战(10)——KNN模型的应用

    # 导入第三方包import pandas as pd # 导入数据Knowledge = pd.read_excel(r'F:\\python_Data_analysis_and_mining\\1 ...

  9. Numpy统计

    Numpy统计 axis=None 是统计函数的标配参数,默认不输入此参数则为对数组每一个元素进行计算,设定轴则对此轴上元素进行计算 1:常用统计函数 .sum(a,axis=None):数组a求和运 ...

  10. python引入模块时import与from ... import的区别(转)

    import datetime是引入整个datetime包,如果使用datetime包中的datetime类,需要加上模块名的限定. 1 import datetime 2 3 print datet ...