用python读取oracle的clob类型数据的处理

用python cx_Oracle读取oracle数据,存在clob类型数据,利用
dbms_lob.substr(extension,4000)来转换成python的str类型,大于3200时候会报错(很多地方是4000,应该是其他设置原因)
ORA-06502: PL/SQL: 数字或值错误 :  字符串缓冲区太小
针对此问题解决方法:
1 直接读取clob数据 ,其数据类型在oracle为cx_Oracle.clob,
2 通过如下方式可以读取clob数据:
     text = cursor.fetchmany(1)
        pram = ''
        if text:
            if text[0][12]:
                for item in text[0][12].read():
                    pram += item
                new_text = list(text[0])
                new_text[12] = pram
                text = [tuple(new_text)]
 即实际类型为一个生成器,迭代即可获取所有数据组成字符串
注明:

text数据的clob不能转存,比如fetchmany为100,就会报错

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值