在oracle的数据类型中,long类型算是一个比较另类的典型,早就不建议使用了,但是在数据字典里还是能看到long 类型的影子。
如果在一些工作中碰到long type就让人感觉long 类型像是被封杀了,会碰到不少的问题。
比如数据字典user_constraints中包含了long类型的列。
SQL> desc user_constraints
Name Null? Type
----------------------------------------- -------- ----------------------------
OWNER VARCHAR2(30)
CONSTRAINT_NAME NOT NULL VARCHAR2(30)
CONSTRAINT_TYPE VARCHAR2(1)
TABLE_NAME NOT NULL VARCHAR2(30)
SEARCH_CONDITION LONG
R_OWNER VARCHAR2(30)
R_CONSTRAINT_NAME VARCHAR2(30)
DELETE_RULE VARCHAR2(9)
STATUS VARCHAR2(8)
DEFERRABLE VARCHAR2(14)
DEFERRED VARCHAR2(9)
VALIDATED VARCHAR2(13)
GENERATED VARCHAR2(14)
BAD VARCHAR2(3)
RELY VARCHAR2(4)
LAST_CHANGE DATE
INDEX_OWNER VARCHAR2(30)
INDEX_NAME VARCHAR2(30)
INVALID VARCHAR2(7)
VIEW_RELATED VARCHAR2(14)
如果我们要创建一个表,存放user_constraints里的数据,就会碰一鼻子灰。
SQL> create table test2 as select *from user_constraints;
create table test2 as select *from user_constraints
*
ERROR at line 1:
ORA-00997: illegal use of LONG datatype
这个错误的解释如下:
SQL> !oerr ora 00097
00097, 00000, "use of Oracle SQL feature not in SQL92 %s Level"
// *Cause: Usage of Oracle's SQL extensions.
// *Action:
对于long类型,倒是有提供一个包来做long类型的转换。如果只是简单的数据,使用包就感觉有些麻烦了。
使用exp/imp貌似是一种方式,不过话说过来,如果没有创建好test_test这个表的话,exp/imp也是无计可施。
如果那个Long列不需要的话,还可以在sql语句里把列名都一一列上,当然这方法就有些体力活了。
如果想快速复制数据而且不希望sql命令太复杂,可以考虑copy命令。
SQL> copy from n1/n1@testdb -
> to n1/n1@testd -
> create test_test -
> using select *from user_constraints
Array fetch/bind size is 15. (arraysize is 15)
Will commit when done. (copycommit is 0)
Maximum long size is 80. (long is 80)
Table TEST_TEST created.
20 rows selected from n1@testd .
20 rows inserted into TEST_TEST.
20 rows committed into TEST_TEST at n1@testdb.
SQL> desc test_test
Name Null? Type
----------------------------------------- -------- ----------------------------
OWNER VARCHAR2(30)
CONSTRAINT_NAME NOT NULL VARCHAR2(30)
CONSTRAINT_TYPE VARCHAR2(1)
TABLE_NAME NOT NULL VARCHAR2(30)
SEARCH_CONDITION LONG
R_OWNER VARCHAR2(30)
R_CONSTRAINT_NAME VARCHAR2(30)
DELETE_RULE VARCHAR2(9)
STATUS VARCHAR2(8)
DEFERRABLE VARCHAR2(14)
DEFERRED VARCHAR2(9)
VALIDATED VARCHAR2(13)
GENERATED VARCHAR2(14)
BAD VARCHAR2(3)
RELY VARCHAR2(4)
LAST_CHANGE DATE
INDEX_OWNER VARCHAR2(30)
INDEX_NAME VARCHAR2(30)
INVALID VARCHAR2(7)
VIEW_RELATED VARCHAR2(14)