数字

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


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. bootstrap修改勾选样式

    小对勾需要引入awesome插件. css部分: .bella-checkbox{ position: relative;}/** 将初始的checkbox的样式改变 */.bella-checkbo ...

  2. [ilink32 Error] Error: Unresolved external 'SendARP'

    [ilink32 Error] Error: Unresolved external 'SendARP' referenced from E:\APPOBJ\KSRGETMAC.OBJ #pragma ...

  3. js倒计时发送验证码按钮

    var wait=60; function time(o) { if (wait == 0) { o.removeAttribute("disabled"); o.value=&q ...

  4. [转]被玩坏的innerHTML、innerText、textContent和value属性

    一.前言 由于innerText并非W3C标准属性,因此我们无法在FireFox中使用它,一般情况下我们可以使用textContent来代替,但它两者是否就能完全等同呢?在坑爹的表单元素(如input ...

  5. r.js打包

    久闻r.js的大名,但实际没有用它做过任何东西.今天用它时,发现网上许多教程都不对.研究一下,把我的实际经验分享给大家. 例子1 先是HTML页面 <!DOCTYPE html> < ...

  6. Delphi声明Record变量后直接初始化

    TARec = record    A1: string;    A2: string;  end; TBRec = record    A1: string;    A2: string;    A ...

  7. Mysql生成索引的方式

    1.选择索引的数据类型 MySQL支持很多数据类型,选择合适的数据类型存储数据对性能有很大的影响.通常来说,可以遵循以下一些指导原则: (1)越小的数据类型通常更好:越小的数据类型通常在磁盘.内存和C ...

  8. 读取数据库信息并生成表设计文档Word版本

    1.参考C#代码 using Help.DBAccessLayer.Business; using Help.DBAccessLayer.Model.SqlGenerator; using Newto ...

  9. 奶牛易物小组 Alpha冲刺

    项目地址:https://gitee.com/rrycbar/NenuChange 1 第一天 日期:2018/6/14 1.1 今日完成任务情况以及遇到的问题. 吴建瑜: 完成任务: 1.继续完善购 ...

  10. ubuntu修改运行级别方法

    Ubuntu系统设置启动级别的问题,因自己以前遇到过,故做过笔记记录了下来:Ubuntu.Debian系列与RedHat.CentOS启动级别含义有所区别:Ubuntu系列运行级别定义如下:0 – H ...