oracle数值格式非法,ORA-00997: 非法使用 LONG 数据类型

博客内容涉及在Oracle数据库中遇到的Long类型数据更新错误,指出应避免使用Long类型并推荐使用Blob替代。作者尝试使用sys.dbms_metadata_util.long2varchar函数转换Long到VARCHAR2,但仍然遇到错误。总结中强调了在数据库设计时考虑数据类型的合适性以及处理Long类型数据的挑战。
摘要由CSDN通过智能技术生成

SQL> desc liuwenhe.DPT_DEATAIL_20150718

Name                                      Null?    Type

----------------------------------------- -------- ----------------------------

PRODUCT_ID                                NOT NULL NUMBER(38)

DETAIL                                             LONG

URL                                                VARCHAR2(1000)

SQL> desc pd_zh_cn.tb_goods;

Name                                      Null?    Type

----------------------------------------- -------- ----------------------------

ID                                        NOT NULL NUMBER(10)

CLASSIFY_ONE                                       NUMBER(10)

CLASSIFY_TWO                                       NUMBER(10)

CLASSIFY_THREE                                     NUMBER(10)

CLASSIFY_FOUR                                      NUMBER(10)

SOURCE_STATION_ID                                  VARCHAR2(20)

SHOP_ID                                   NOT NULL NUMBER(10)

BRAND_ID                                           NUMBER(10)

IS_ONLINE                                          NUMBER(2)

TITLE                                     NOT NULL VARCHAR2(4000)

IMG_URL                                            VARCHAR2(4000)

DETAIL_ADDRESS                                     VARCHAR2(4000)

执行更新:

update pd_zh_cn.tb_goods a set a.detail_address=

(select   b.DETAILfrom liuwenhe.DPT_DEATAIL_20150718 b where b.product_id=a.id);

报错:‘ORA-00997: 非法使用 LONG 数据类型’

通过sys.dbms_metadata_util.long2varchar函数,将long属性转换为varchar2

update pd_zh_cn.tb_goods a set a.detail_address=

(select (sys.dbms_metadata_util.long2varchar(1000, 'liuwenhe.DPT_DEATAIL_20150718', 'DETAIL', ROWID))

from liuwenhe.DPT_DEATAIL_20150718 b where b.product_id=a.id);

小结 oracle应该尽量避免使用long类型,取而代之  blob

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值