First, the table below describes the ing relationship with the DB2/400 data types, which is a one-to-many relationship. The specific ing relationship should be analyzed for specific issues.
Note:
The DATE in Oracle contains the year, month, day, hour, minute, and second. It does not correspond to the DATE in DB2/400. The DATE in DB2/400 only includes the year, month, and day, the TIME type includes TIME, minute, and second. Therefore, to convert the date and TIME types, see the following table.
Oracle
|
|
DB2/400 |
|
Oracle Data Type
|
Notes |
DB2 UDB Data Type |
Notes |
DATE |
|
DATE TIME TIMESTAMP l |
If only MM/DD/YYY is used, the DATE type is used. L if only HH: MM: SS is used, the TIME type is used. L if you want to use the date and time, use the TIMESTAMP type) L you can use the TO_CHAR () function in Oracle to obtain the DATE string and match the DATE and TIME of DB2/400 respectively.
|
VARCHAR2 (n) |
N <= 4000 |
CHAR (n) VARCHAR (n) l |
If n <= 32766, the CHAR type and VARCHAR type in DB2/400 are used. |
LONG |
N <= 2 GB |
VARCHAR (n) CLOB (n) l |
If n <= 32 K, CHAR and VARCHAR in DB2/400 are used. L if 32 K = <n <= 2 GB, CLOB is used. |
ROW & LONG ROW |
N <= 255 |
CHAR (n) FOR BIT DATA VARCHAR (n) FOR BIT DATA BLOB (n) l |
If n <= 32 K, CHAR (n) for bit data or VARCHAR (n) FOR BIT DATA L if n <= 2 GB, BLOB (n) is used) |
BLOB |
N <= 4 GB |
BLOB (n) |
If n <= 2 GB, BLOB (n) is used) |
CLOB |
N <= 4 GB |
CLOB (n) |
If n is <= 2 GB, CLOB (n) is used) |
NCLOB |
N <= 4 GB |
DBCLOB (n) |
If n is <= 2 GB, DBCLOB (n/2) is used) |
NUMBER |
SMALLINT/INTEGER/BIGINT DECIMAL (p, s)/NUMBER (p, s) Float (n)/REAL/DOUBLE l |
VARCHAR |
If NUMBER (p) or NUMBER (p, s) is defined in Oracle, SAMLLINT/INTEGER/BIGINT L if NUMBER (p, s) is defined in Oracle, DECIMAL (p, s) is used) L if NUMBER is defined in Oracle, FLOAT (n)/REAL/DOUBLE is used. |
NUMBER
The NUMBER type in Oracle can correspond to many types in DB2/400. This relationship depends on the type of data in Oracle that number will be used to store, whether it is integer or real-type data with decimal places, in addition, the storage space occupied by the type should be considered. For example, SAMLLINT occupies 2 bytes, INTEGER occupies 4 bytes, and BIGINT occupies 8 bytes; the storage space occupied by the NUMBER type in Oracle depends on its definition. For example, the NUMBER in the default precision is 38 characters long, occupying 20 bytes of space. For specific mappings, see the table above.
ROW and LOB type
DB2/400 provides VARCHAR and CLOB that correspond to RAW and long raw in ORACLE. ORACLE also supports large objects: BLOB, CLOB, CLOB, and NCLOB. BLOB and CLOB in ORACLE can provide 4 GB space, while BLOB and CLOB in DB2/400 can only store 2 GB of data; DBCLOB in DB2/400 corresponds to NCLOB 2 GB in ORACLE. The BFILE data type in Oracle is used to manage binary data other than the database. Tables in the database point to the BFILE file stored outside the database. DB2/400 also provides a similar data type corresponding to DATALINK.
ROWID
The Oracle ROWIND virtual column is used to uniquely identify a column in the table. This data type also exists in DB2/400, which is similar to the ROWID function in ORACLE. ROWID in DB2/400 can store 40 bytes of data to uniquely identify each row in the table. It does not have the ccsid attribute and does not contain information about datafile, block, or row.
For example:
Create table libraryname/ORDERS2 (orderno rowid, SHIPPED_TO VARCHAR (36), ORDER_DATE DATE) the data type of ORDERNO is ROWID, which is used to store the order number. When a row is inserted, the system automatically generates a value, enter this field. You can use operation navigator to view its content.
Character type
The CHAR and VARCHAR types of DB2/400 correspond to the VARCHAR2 (n) types in ORACLE, but the VARCHAR2 (n) type in ORACLE is only used to store small strings, here n is less than 4000, so in this case, it is best to use a fixed length CHAR (N) type to correspond to the ORACLE VARCHAR2 (n), which not only improves the efficiency, it can also save storage space. If VARCHAR (n) type is used, it is best to use the ALLOCATE parameter, which can improve database performance and reduce input/output operations between memory and hard disk.
Pay attention to the problem of string Chinese Input in DB2/400. To enter an SQL statement such as Chinese application on DB2/400, the CCSID 935 here represents Simplified Chinese.