DB2数据类型(抄袭)
数字
数据类型 精度 最小值 最大值
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
DB2数据类型(抄袭)的更多相关文章
- DB2数据类型
DB2数据库的内置数据类型主要分成数值型(numeric).字符串型(character string).图形字符串(graphic string).二进制字符串型(binary string)或日期 ...
- db2 数据类型
数据类型: 字符串类型 描述 CHARACTER(n) n bytes定长字符串. n 大于0 不大于255. 默认 1. VARCHAR(n) 变长字符串,最大 n bytes. n大于 0 小于表 ...
- Oracle VS DB2 数据类型
=========================Oracle VS DB2==================================== 本文转自:http://www.bitscn.co ...
- DB2 Vs MySQL系列 | MySQL与DB2的数据类型对比
随着MySQL数据库的应用越来越广泛,DB2向MySQL数据库的迁移需求也越来越多.进行数据库之间迁移的时候,首先遇到的并且也是最基本最重要的就是两种数据库数据类型之间的转换. 相关阅读: 从商用到开 ...
- DB2常用sql函数 (转载)
http://www.techonthenet.com/sql/index.php 一.字符转换函数 1.ASCII() 返回字符表达式最左端字符的ASCII 码值.在ASCII()函数中,纯数字的字 ...
- Oracle的Numer类型与C,C#数据类型对应关系
最近一直在编和Oracle数据库相关程序.Oracle的Number类型和C语言,C#语言类型的对应关系,在网络上查找很久,也没有找到说明文字.但在http://oracle.chinaitlab.c ...
- db2和oracle字段类型对比
在网上找到一片关于oracle与DB2数据类型的比较,特记下来. Oracle DB2/400 Oracle数据类型 注意事项 DB2 UDB数据类型 注意事项 DATE DATETIMETIMEST ...
- 从商用到开源:15个维度,全面剖析DB2与MySQL数据库的差异
随着MySQL数据库的应用越来越广泛,DB2向MySQL数据库的迁移需求也越来越多.进行数据库之间迁移的时候,首先遇到的并且也是最基本最重要的就是两种数据库数据类型之间的转换. 相关阅读: 从商用到开 ...
- DB2的sql函数
转自:http://blog.chinaunix.net/uid-21162795-id-3587646.html 一.字符转换函数 1.ASCII() 返回字符表达式最左端字符的ASCII 码值.在 ...
随机推荐
- spring boot 整合 (全)
参考: https://github.com/spring-projects/spring-boot/tree/master/spring-boot-samples
- ubuntu 安装 环境
svn https://blog.csdn.net/leibris/article/details/72982804 https://blog.csdn.net/frankchen ...
- leetcode242
public class Solution { public bool IsAnagram(string s, string t) { Dictionary<char, int> dic ...
- MS SQL 2005 无法建立用户实例
SC.EXE stop "MSSQL$SQLEXPRESS"RD /S /Q "%USERPROFILE%\Local Settings\Application Data ...
- jdk下载--操作系统
不同的操作系统需要下载不同的jdk. 查看操作系统的命令: Window系统下:>winver Linux和Unix系统下: >uname -a 根据系统不同选用不同的jdk: 下载地址: ...
- AKKA集群中的分布式发布订阅
集群中的分布式发布订阅 如何向一个不知道在哪个节点上运行的actor发送消息呢? 如何向集群中的所有actor发送感兴趣的主题的消息? 这种模式提供了一个中介actor,akka.cluster.pu ...
- JFR 与 JProfilter Jvmisualvm
只有JFR 是可以在生产环境使用 采用C++独立写的采样手机功能 而 JProfilter/JVisualvm 都只能在测试环境下使用 使用instrument 机制 ,还有debug 框架 最早是 ...
- vue 实例生命周期
compile template into render function 编译模板渲染方法 compile el’s ouoterHtml as template 将el的outerHTML当做模板 ...
- poj3616(LIS简单变式)
题目链接:http://poj.org/problem?id=3616 思路: 我的第一反应是背包,因为每个interval要么选择要么不选,后来发现状态方程很难写出来.后来想一想发现就是LIS的简单 ...
- python的多线程和守护线程
1.创建一个多线程 import threading import time ''' def threading_func(num): print("running on number:%s ...