数字

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


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. JS 操作 file标签只上传照片

    在当前高版本浏览器里 在标签里加这个属性就够用了 accept="image/*" $('input[type="file"]').live('change', ...

  2. Spring MVC 视图及视图解析器

    org.springframework.web.servlet.view.InternalResoureceViewResolve 把逻辑视图改为物理视图 可混用多种视图 不进过Handler直接进入 ...

  3. BLOB 操作

    对于数据库是BLOB类型存储数据. BLOB数据插入: Oracle提供的标准方式: 先插入一个空BLOB对象,然后Update这个空对象. 首先使用empty_blob()函数插入一个空BLOB对象 ...

  4. chrome 设置是否缓存

    在进行本地开发时,因老需要修改js,css等文件,而页面又带有缓存因此无法自动更新为新的文件. 在页面点击 -> F12 ->F1 ->References -> NetWor ...

  5. ubuntu查询可用安装包

    当使用apt-get install packages时,如果不知道安装包的具体名称,可以使用关键字进行搜索,使用:apt-cache search keywords

  6. 调整Mic音量

    uses  MMSystem; function GetLineInHandle(AudioType : integer) : integer;var  i : integer;  AudioCaps ...

  7. scala -- 递归 实现 斐波那契函数

    求一个起始为0,1,1,2,3的斐波那契序列 def main(args: Array[String]): Unit = { def fib(n: Int): Int = { if (n == 1) ...

  8. mysql 导入csv 转义

    TERMINATED :分隔符 ESCAPED :转义用什么标示,‘’ 不设置转义符 LOAD DATA LOCAL INFILE '/home/tmp/1999/holder.csv'  INTO ...

  9. HTTP协议图示详解

    一.概念 协议是指计算机通信网络中两台计算机之间进行通信所必须共同遵守的规定或规则,超文本传输协议(HTTP)是一种通信协议,它允许将超文本标记语言(HTML)文档从Web服务器传送到客户端的浏览器. ...

  10. springmvc后台生成验证码

    url http://localhost:8080/admin/getCode http://localhost:8080/admin/checkCode controller package com ...