cx_oracle不能写入,cx_Oracle.NotSupportedError:Python值无法转换为数据库值

这个问题已经被报告了here,你可以看看那里的评论。在

错误的原因是,在第一批处理中,一个或多个要绑定的列始终是None,但在随后的批处理中,这些列中的一个列现在有一个值。在cx_Oracle源代码中已经更正了这一点,因此您可以自行构建,也可以等待补丁发布。在

否则,目前的解决方案如下:

(1)在一批中执行所有插入操作(但根据大小,这可能无法使用)

(2)为每个批创建一个新的游标(以便cx嫒Oracle计算每个批的类型)

(3)使用cursor.setinputsizes()指定类型和尺寸(可能很麻烦)

演示问题的简单测试用例如下:import cx_Oracle

conn = cx_Oracle.connect("cx_Oracle/welcome")

cursor = conn.cursor()

cursor.execute("truncate table TestTempTable")

sql = "insert into TestTempTable values (:1, :2)"

cursor.executemany(sql, [(1, None), (2, None)])

cursor.executemany(sql, [(3, None), (4, "Testing")])

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值