apple_pingwan 2021-10-09 20:22 采纳率: 0%
浏览 20

oracle数据库clob大字段数据的新增及修改问题

相同代码相同数据相同数据库字段类型,在开发本地,应用程序对clob字段进行新增及修改操作,执行成功;在用户使用的正式环境,新增及修改操作失败。

img

这个也是从网上查找的方法,在开发本地正常,用户环境失败。

其中,用户环境数据库版本:Oracle Database 12c Enterprise Edition Release 12.1.0.2.0 - 64bit Production
本地开发环境数据库版本: Oracle Database 12c Enterprise Edition Release 12.2.0.1.0 - 64bit Production

现急切需要大家指点迷津,谢谢

  • 写回答

1条回答 默认 最新

  • 唯一的小彬哥 2021-10-11 13:44
    关注

    1.驱动问题,确保连接Oracle的驱动版本保持比较新的版本
    2.你在使用PreparedStatement的时候绑定类型错误。使用setString 时小于4000字符是没问题,但是超过4000就必须用setClob才行。所以有一种可能就是你在测试环境时数据小于4000就没问题,然后再用户使用环境可能超过4000所以就出错了。
    如果想了解更多数据库知识可以关注我的公众号:唯一的小彬哥

    下面是我自己封装的绑定变量的代码片段,CLOB部分的代码片段。你可以参考一下

    
    case DataType.LONG:
        pstmt.setLong(j + 1, Long.parseLong(config.getBindValue(j)));
         break;
     case DataType.CLOB:
        
          if (config.getBindValue(j) == null || config.getBindValue(j).trim().length() == 0) {
             pstmt.setString(j + 1, config.getBindValue(j));
          } else {
               StringReader reader = new StringReader(config.getBindValue(j));
              pstmt.setClob(j + 1, reader, config.getBindValue(j).length());
          }
         break;
    
    评论

报告相同问题?

问题事件

  • 修改了问题 10月9日
  • 创建了问题 10月9日

悬赏问题

  • ¥15 cgictest.cgi文件无法访问
  • ¥20 删除和修改功能无法调用
  • ¥15 kafka topic 所有分副本数修改
  • ¥15 小程序中fit格式等运动数据文件怎样实现可视化?(包含心率信息))
  • ¥15 如何利用mmdetection3d中的get_flops.py文件计算fcos3d方法的flops?
  • ¥40 串口调试助手打开串口后,keil5的代码就停止了
  • ¥15 电脑最近经常蓝屏,求大家看看哪的问题
  • ¥60 高价有偿求java辅导。工程量较大,价格你定,联系确定辅导后将采纳你的答案。希望能给出完整详细代码,并能解释回答我关于代码的疑问疑问,代码要求如下,联系我会发文档
  • ¥50 C++五子棋AI程序编写
  • ¥30 求安卓设备利用一个typeC接口,同时实现向pc一边投屏一边上传数据的解决方案。