当前位置:  数据库>oracle

Oracle数据库LONG类型移植

    来源: 互联网  发布时间:2017-04-13

    本文导语: LONG类型字段很原始使用时限制也很多,与LONG类型相对应的类型有CLOB,LONG类型虽然已经不建议使用但还是可以发现在Oracle数据字典相关的视图中还是有LONG类型的身影。 LONG类型的移植 可以直接通过DDL方式显示的修改成LONG类型...

LONG类型字段很原始使用时限制也很多,与LONG类型相对应的类型有CLOB,LONG类型虽然已经不建议使用但还是可以发现在Oracle数据字典相关的视图中还是有LONG类型的身影。

  • LONG类型的移植
  • 可以直接通过DDL方式显示的修改成LONG类型:
  • 可以通过TO_LOB相关函数,将原始LONG类型的列通过TO_LOB处理后放到新的列,再把LONG类型的列删除。
  • 相关SQ
  • --建表

    CREATE TABLE TEST_LONGTYPE_TABLE(

           ID VARCHAR2(20) NOT NULL,

           TEXT_LONG LONG,

           TEXT_CLOB CLOB

    )

    --直接显示更改类型,注意此种办法是不可逆的(变LONG为CLOB后不可以再改回来)

    ALTER TABLE TEST_LONGTYPE_TABLE MODIFY TEXT_LONG CLOB;

    --向LONG的列插入数据

    INSERT INTO TEST_LONGTYPE_TABLE(ID, TEXT_LONG) VALUES('001', 'LONG类型');

    --用TO_LOB转换后数据放到CLOB中

    INSERT INTO TEST_LONGTYPE_TABLE(ID, TEXT_CLOB) SELECT ID, TO_LOB(TEXT_LONG) FROM TEST_LONGTYPE_TABLE

  • 带有LONG类型列不能使用UNION但可以使用UNION ALL
  • 合法
  • SELECT * FROM TEST_LONGTYPE_TABLE UNION ALL SELECT * FROM TEST_LONGTYPE_TABLE

    非法

    SELECT * FROM TEST_LONGTYPE_TABLE UNION SELECT * FROM TEST_LONGTYPE_TABLE

  • 在存储过程中使用了LONG
  • CREATE OR REPLACE PROCEDURE WYC_LONGTYPE_TEST IS
  •   A1_LONG LONG;

      A2_LONG LONG;

    BEGIN

      FOR C IN (SELECT A_DATADF, B_DATADF

                  FROM (SELECT A.TABLE_NAME,

                               A.COLUMN_NAME,

                               A.DATA_TYPE      A_DT,

                               B.DATA_TYPE      B_DT,

                               A.DATA_LENGTH    A_DLEN,

                               B.DATA_LENGTH    B_DLEN,

                               A.DATA_PRECISION A_DPREC,

                               B.DATA_PRECISION B_DPREC,

                               A.DATA_SCALE     A_DSCA,

                               B.DATA_SCALE     B_DSCA,

                               A.NULLABLE       A_NULLA,

                               B.NULLABLE       B_NULLA,

                               A.DEFAULT_LENGTH A_DEFLEN,

                               B.DEFAULT_LENGTH B_DEFLEN,

                               A.DATA_DEFAULT   A_DATADF,

                               B.DATA_DEFAULT   B_DATADF

                          FROM (SELECT TABLE_NAME,

                                       COLUMN_NAME,

                                       DATA_TYPE,

                                       DATA_LENGTH,

                                       DATA_PRECISION,

                                       DATA_SCALE,

                                       NULLABLE,

                                       DEFAULT_LENGTH,

                                       DATA_DEFAULT

                                  FROM ALL_TAB_COLS ACT1

                                 WHERE OWNER = 'USER_A'

                                   AND EXISTS

                                 (SELECT 1

                                          FROM ALL_TAB_COLS ATC2

                                         WHERE ATC2.OWNER = 'USER_B'

                                           AND ATC2.TABLE_NAME = ACT1.TABLE_NAME)) A,

                               (SELECT TABLE_NAME,

                                       COLUMN_NAME,

                                       DATA_TYPE,

                                       DATA_LENGTH,

                                       DATA_PRECISION,

                                       DATA_SCALE,

                                       NULLABLE,

                                       DEFAULT_LENGTH,

                                       DATA_DEFAULT

                                  FROM ALL_TAB_COLS ACT1

                                 WHERE OWNER = 'USER_B'

                                   AND EXISTS

                                 (SELECT 1

                                          FROM ALL_TAB_COLS ATC2

                                         WHERE ATC2.OWNER = 'USER_A'

                                           AND ATC2.TABLE_NAME = ACT1.TABLE_NAME)) B

                         WHERE A.TABLE_NAME = B.TABLE_NAME

                           AND A.COLUMN_NAME = B.COLUMN_NAME) C

                 WHERE C.A_DEFLEN C.B_DEFLEN) LOOP

                 A1_LONG := C.A_DATADF;

                 A2_LONG := C.B_DATADF;

        DBMS_OUTPUT.put_line('Step_1_A1_LONG/A2_LONG 长度:' || LENGTH(A1_LONG) || '/' || LENGTH(A2_LONG));

                 A1_LONG := TRIM(A1_LONG);

                 A2_LONG := TRIM(A2_LONG);

        DBMS_OUTPUT.put_line('Step_2_A1_LONG/A2_LONG 长度:' || LENGTH(A1_LONG) || '/' || LENGTH(A2_LONG));        

        DBMS_OUTPUT.put_line('Step_3_A1_LONG/A2_LONG 内容:' || TO_CHAR(A1_LONG) || '/' || TO_CHAR(A2_LONG));

        IF (C.A_DATADF = C.B_DATADF) THEN

          DBMS_OUTPUT.put_line('相等性');

        ELSE

          DBMS_OUTPUT.put_line('不相等');

        END IF;

      END LOOP;

    END WYC_LONGTYPE_TEST;

    /


        
     
     

    您可能感兴趣的文章:

  • 将Oracle 8i数据成功移植Oracle 10g的方法
  • Informix 移植到 Oracle 的问题
  • MySQL 移植到Oracle10 的问题
  • 不安装ORACLE客户端的系统移植方法
  • Windows下Oracle 10G数据库移植到Linux平台
  • ORACLE数据库常用字段数据类型介绍
  • oracle中的空类型与c语言的空类型相匹配吗?
  • 关于Oracle BLOB类型,一个String字符怎么写入BLOB字段?
  • Oracle中查看某列数据类型
  • 测试添加Oracle中Blob数据类型对象
  • jsp文件上传smartupload到oracle数据库中没有longblob的数据类型如何处理的?
  • oracle中 VARCHAR2是什么数据类型
  • 请问保存文章内容的字段应用什么类型的(oracle),急!!!
  • oracle中怎么没有boolean类型的字段?应该用什么代替?
  • 如何向oracle库中字段类型是date的添加数据
  • 请问:ORACLE中的数据取出来后,需不需要进行一定的转换才能变为C语言的数据类型啊?
  • jsp中在oracle中查询日期类型时sql语句该怎么写啊?
  • 怎样将当前时间写到Oracle中date类型的字段中!!!!!!!!!!!!
  • 急!急!oracle 中 long 类型在 tomcat 中的问题
  • 不能把几百个以上的汉字插入oracle varchar2类型的问题!
  • Oracle里long类型
  • jsp显示oracle中varchar2类型字段 在线等待
  • Oracle中的Raw类型解释
  • 我要向oracle中插入大文本,用的是lang类型的字段,但是只能插3000字,再多就抱错,说我字符串过长。谁遇到过此问题?
  • Oracle返回表类型的自定义函数
  • Oracle中字符集的类型决定varchar2的字符长度
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • Oracle 数据库开发工具 Oracle SQL Developer
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • Oracle 数据库(oracle Database)性能调优技术详解
  • 关于JDBC连接Oracle数据库,是否必须有Oracle客户端
  • win2000+jbuilder6+oracle817编出的程序,在win2000下执行很好,在win98下却访问不了oracle数据库
  • oracle数据库导出和oracle导入数据的二种方法(oracle导入导出数据)
  • Oracle发布Oracle SQL Developer 1.2数据库开发工具 帮助用户简化开发工作
  • 怎样调出ORACLE数据库中的数据,该如何连接?
  • Oracle收购TimesTen 提高数据库软件性能
  • unix/linux知识 iis7站长之家
  • Oracle数据库恢复后心得
  • linux上安装oracle 数据库后,是否能写shell程序实现数据库的自动启动。
  • Linux下如何用C语言操作Oracle数据库相关的图书推荐
  • Oracle数据库运行Oracle form时避免出现提示信息
  • Oracle欲收购开源数据库MySQL未果
  • 如何在JBuilder中连接Oracle数据库?
  • Oracle数据库访问参数文件的顺序
  • 循序渐进学习Oracle数据库
  • 安装Oracle加载数据库错误areasQueries的解决
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle 10g和Oracle 11g网格技术介绍
  • Oracle EBS R12 支持 Oracle Database 11g
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3