`
lxtkong-029
  • 浏览: 3840 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

oracle中blob字段数据无法修改问题

    博客分类:
  • java
阅读更多

if ("modify".equals(flag)){ try { String selectName = ""; String selectIp = ""; String selectPort = ""; int selectAUDIT_STATUS = 0; BLOB blob = null; String name = request.getParameter("Name");//名称唯一性标识 String configFileStr = request.getParameter("CONFIG");//xml内容字符串 db = ConnectionPool.getInstance(); conn = db.getConnection(); conn.setAutoCommit(false); //从数据库取得此条数据 String StrSQL = "select * from SYS_MERGECONFIG where ID = '" + name + "'"; stmt = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE); ResultSet rs = stmt.executeQuery(StrSQL); if (rs.next()) { selectName = rs.getString("ID"); selectIp = rs.getString("IP"); selectPort = rs.getString("PORT"); } //删除此数据 String deletSql = "delete from SYS_MERGECONFIG where ID =?"; ps = conn.prepareStatement(deletSql); ps.setString(1, selectName); ps.executeUpdate(); rs.close(); //重新插入:EMPTY_BLOB(); String insertSql = "insert into SYS_MERGECONFIG(ID,IP,PORT,AUDIT_STATUS,CONFIG) values(?,?,?,?,EMPTY_BLOB())"; ps = conn.prepareStatement(insertSql); ps.setString(1, selectName); ps.setString(2, selectIp); ps.setString(3, selectPort); ps.setInt(4, selectAUDIT_STATUS); ps.executeUpdate(); //查询此行数据并锁定 ps = conn.prepareStatement("select CONFIG from SYS_MERGECONFIG where ID=? for update"); ps.setString(1,name); ResultSet rset = ps.executeQuery(); if (rset.next()){ blob = (BLOB) rset.getBlob("CONFIG"); } //对锁定数据修改 ps = conn.prepareStatement("update SYS_MERGECONFIG set CONFIG=? where ID=?"); OutputStream out = blob.getBinaryOutputStream(); byte data[] = configFileStr.getBytes("utf-8"); out.write(data); out.close(); ps.setBlob(1,blob); ps.setString(2,name); ps.executeUpdate(); ps.close(); conn.commit(); conn.close(); response.getOutputStream().println(configFileStr); response.flushBuffer(); response.getOutputStream().close(); return; } catch (Exception e) { log.writeError(1, 1, 1, "修改合并条件有误", e.getMessage()); try { response.getOutputStream().println(getFail("修改合并条件有误")); response.flushBuffer(); response.getOutputStream().close(); } catch (IOException e1) { e1.printStackTrace(); } } finally { try { db.freeConnection(conn); } catch (Exception e) { e.getMessage(); } }

1
1
分享到:
评论

相关推荐

    oracle中对blob字段的处理方法

    oracle中对blob字段的处理方法,包括增加,删除,修改,更新等操作。

    批量导出ORACLE数据库BLOB字段生成图片

    Oracle数据库在存储大对象...总之,批量导出Oracle数据库中的BLOB字段生成图片涉及到了数据库连接、SQL查询、BLOB数据处理和文件I/O等多个技术环节。掌握这些知识点对于管理和维护包含二进制数据的数据库系统至关重要。

    ORACLE中BLOB字段导入到SQL SERVER中的IMAGE字段

    1. **数据准备**:确保ORACLE数据库中的BLOB字段包含所需的数据,并且是完整的。可能需要进行数据验证,以确保所有数据都能被正确读取。 2. **数据导出**:使用ORACLE提供的工具,如SQL*Plus或者PL/SQL Developer,...

    批量导出ORACLE数据库BLOB字段生成文件

    本教程将详细讲解如何批量导出Oracle数据库中的BLOB字段并生成文件,适用于需要定期或一次性处理大量图片或其他BLOB数据的场景。 首先,确保你已经在本地安装了Oracle客户端。Oracle客户端提供了SQL*Plus和其他工具...

    Python如何操作Oracle的Blob字段

    Python如何操作Oracle的Blob字段,

    oracle查询blob字段照片(jpeg) 像素大小sql

    本篇文章将详细介绍如何通过SQL查询语句获取存储在Blob字段中的JPEG格式照片的像素大小。 ### 1. 了解Blob数据类型 在Oracle数据库中,Blob(Binary Large Object)类型用于存储大容量的二进制数据,比如图像、音频...

    oracle中读取blob字段.doc

    在Java应用程序中读取Oracle数据库中的BLOB字段通常涉及到几个步骤:建立数据库连接、执行查询语句、获取结果集并从中提取BLOB数据,最后将这些数据写入到文件中。 ##### 3.1 加载Oracle驱动 在Java程序中使用...

    java中读取ORACLE中BLOB字段存储的图片

    本文将详细介绍如何在Java应用程序中读取存储在Oracle数据库BLOB字段中的图片数据。 #### 二、准备工作 为了实现读取Oracle数据库中的BLOB字段存储的图片,我们需要进行以下准备: 1. **环境搭建**: - Oracle...

    C#访问oracle数据库类,带blob字段读写

    读取Blob字段时,可以创建一个`OracleBinary`对象,然后使用`GetValue`方法获取Blob数据。写入Blob字段时,先创建`OracleParameter`对象,将其Direction设置为` ParameterDirection.Input `,OracleDbType设置为`...

    基于JSP访问ORACLE数据库BLOB字段并显示图形的解决方案.pdf

    本文介绍了一种基于JSP访问ORACLE数据库BLOB字段并显示图形的解决方案,展示了JSP技术、ORACLE数据库BLOB字段、坐标点的存储和读取、图形的显示、排样数据表设计、Samplegraph.jsp的功能、JAVA类的应用等知识点。

    Oracle blob字段上传下载

    本文将详细介绍如何在Oracle数据库中实现Blob字段的上传和下载操作。 #### 二、Blob字段上传 Blob字段的上传通常涉及到以下几个步骤: 1. **创建Blob字段:** 首先需要在数据库表中定义一个Blob类型的字段。 2. **...

    java对oracle数据库中blob字段的处理

    在IT领域,尤其是在Java开发与...通过上述步骤,可以有效地在Java应用程序中处理Oracle数据库中的BLOB字段,同时解决跨数据库操作中可能遇到的问题。这不仅提高了数据处理的灵活性,也增强了系统的整体功能性和稳定性。

    oracle中的BLOB(照片)转换到mysql中

    1. **查询BLOB数据**:使用SQL查询语句从Oracle数据库中选择含有BLOB字段的照片记录。例如: ```sql SELECT photo_blob FROM photos WHERE id = ; ``` 这里`photo_blob`是BLOB类型的列,`<photo_id>`是你想获取...

    oracle blob 字段 读写 delphi

    本篇文章将深入探讨如何在Delphi中对Oracle数据库的BLOB字段进行读写操作。 首先,你需要在Delphi项目中引入Oracle数据库访问的相关组件,如DBExpress或ADO。DBExpress是Delphi内置的一个轻量级数据库访问框架,而...

    oracle存取图片blob字段

    oracle 存读数据库的blob字段 .net有两种方式向Oracle的blob字段中存储图片:

    Oracle中Blob字段的写入处理

    此文档是对于oracle数据库中blob类型字段二进制大对象的读取和解析

    判断blob字段是否为空

    在关系型数据库中,如Oracle、MySQL、SQL Server等,BLOB字段提供了一种高效的方式,用于处理和存储大数据量的非结构化信息。 ### 判断BLOB字段是否为空的必要性 在实际应用中,判断BLOB字段是否为空对于数据完整...

    oracle中blob 字段类型的应用

    Oracle中的Blob字段类型是用于存储大量二进制数据的数据类型,比如图像、音频或大型文档。Blob代表Binary Large Object,其最大容量可达4GB。在Oracle数据库中,Blob与Clob(Character Large Object)、Bfile和Nclob...

    基于JSP访问ORACLE数据库BLOB字段并显示图形的解决方案

    本文提出的方法有效地解决了通过JSP访问Oracle数据库中的BLOB字段,并将其转化为可视觉化的图形的问题。通过这种方式,不仅能够读取复杂的坐标数据,还能通过Java程序将其转化为直观的图形显示出来,大大提高了数据...

    使用JAVA读取ORACLE_BLOB字段实现上传下载.doc

    使用 JAVA 读取 ORACLE BLOB 字段实现上传下载需要完成以下几个步骤:上传大对象、将大对象存储在数据库中、使用专门的函数来完成 BLOB 的使用。在 Struts 项目中,我们可以使用 Struts 的文件上传组件来上传大对象...

Global site tag (gtag.js) - Google Analytics