述】
    Oracle的Blob字段比较特殊,他比long字段的性能要好很多,可以用来保存例如图片之类的二进制数据。
写入Blob字段和写入其它类型字段的方式非常不同,因为Blob自身有一个cursor,你必须使用cursor对
blob进行操作,因而你在写入Blob之前,必须获得cursor才能进行写入,那么如何获得Blob的cursor呢?
这需要你先插入一个empty的blob,这将创建一个blob的cursor,然后你再把这个empty的blob的cursor
用select查询出来,这样通过两步操作,你就获得了blob的cursor,可以真正地写入blob数据了。
【处理流程】

 

  1. package demo;
  2. import java.sql.*;
  3. import java.io.*;
  4. public class ReadBlob
  5. {
  6. //加载驱动程序
  7. static
  8. {
    1. //读取Blob数据
    2. package demo;
    3. import java.sql.*;
    4. import java.io.*;
    5. public class ReadBlob
    6. {
    7. //加载驱动程序
    8. static
    9. {
    10. try
    11. {
    12. Class.forName("oracle.jdbc.driver.OracleDriver");
    13. } catch (ClassNotFoundException e)
    14. {
    15. // TODO Auto-generated catch block
    16. e.printStackTrace();
    17. }
    18. }
    19. public static void main(String[] args)
    20. {
    21. try
    22. {
    23. //1. 建立连接
    24. String url = "jdbc:oracle:thin:@localhost:1521:OracleDB";
    25. Connection conn = DriverManager.getConnection(url,"scott","tiger");
    26. conn.setAutoCommit(false);
    27. //2. 查询数据
    28. String sql = "select image from user_info where user_id = 1";
    29. Statement stmt = conn.createStatement();
    30. ResultSet rs = stmt.executeQuery(sql);
    31. //3. 读取Blob类型数据
    32. Blob blob = null;
    33. if(rs.next())
    34. {
    35. blob = rs.getBlob(1);
    36. }
    37. byte[] temp = new byte[(int)blob.length()];
    38. InputStream in = blob.getBinaryStream();
    39. in.read(temp)s
    //读取Blob数据
    package demo; import java.sql.*;
    import java.io.*; public class ReadBlob
    {
    //加载驱动程序
    static
    { try
    {
    Class.forName("oracle.jdbc.driver.OracleDriver");
    } catch (ClassNotFoundException e)
    {
    // TODO Auto-generated catch block
    e.printStackTrace();
    }
    } public static void main(String[] args)
    {
    try
    {
    //1. 建立连接
    String url = "jdbc:oracle:thin:@localhost:1521:OracleDB";
    Connection conn = DriverManager.getConnection(url,"scott","tiger");
    conn.setAutoCommit(false); //2. 查询数据
    String sql = "select image from user_info where user_id = 1";
    Statement stmt = conn.createStatement();
    ResultSet rs = stmt.executeQuery(sql); //3. 读取Blob类型数据
    Blob blob = null;
    if(rs.next())
    {
    blob = rs.getBlob(1);
    }
    byte[] temp = new byte[(int)blob.length()];
    InputStream in = blob.getBinaryStream();
    in.read(temp)s
    1. <strong>//保证文件名唯一,你可以用主键+时间啊等等方法</strong>
    2. File file = new File("D://img.bmp");
    3. FileOutputStream fout = new FileOutputStream(file);
    4. fout.write(temp);
    5. in.close();
    6. fout.close();
    7. } catch (Exception e)
    8. {
    9. // TODO Auto-generated catch block
    10. e.printStackTrace();
    11. }
    12. }
    13. }
    			//保证文件名唯一,你可以用主键+时间啊等等方法
    File file = new File("D://img.bmp");
    FileOutputStream fout = new FileOutputStream(file);
    fout.write(temp);
    in.close();
    fout.close();
    } catch (Exception e)
    {
    // TODO Auto-generated catch block
    e.printStackTrace();
    }
    }
    }
  1. package demo;
  2. import java.sql.*;
  3. import oracle.sql.BLOB;//▲此处的BLOB类全大写, 而java.sql.Blob中的Blob非全大写
  4. import java.io.*;
  5. public class WriteBlob
  6. {
  7. //加载驱动程序
  8. static
  9. {
  10. try
  11. {
  12. Class.forName("oracle.jdbc.driver.OracleDriver");
  13. }
  14. catch(Exception e)
  15. {
  16. e.printStackTrace();
  17. }
  18. }
  19. public static void main(String[] args)
  20. {
  21. try
  22. {
  23. //1. 建立与数据库服务器的连接
  24. String url = "jdbc:oracle:thin:@localhost:1521:OracleDB";
  25. Connection conn = DriverManager.getConnection(url,"scott","tiger");
  26. conn.setAutoCommit(false);
  27. //2. 首先向表中插入空的Blob
  28. //★注意: 对于empty_blob()应放在SQL语句中直接赋值, 使用预置语句的方式赋值无法实现.
  29. String sql = "insert into user_info values(?,?,empty_blob())";
  30. PreparedStatement ps = conn.prepareStatement(sql);
  31. ps.setInt(1, 1);
  32. ps.setString(2, "Lucy");
  33. ps.executeUpdate();
  34. //3. 查询Blob, 获得Blob的Cursor
  35. sql = "select image from user_info where user_id = ?";
  36. ps = conn.prepareStatement(sql);
  37. ps.setInt(1, 1);
  38. ResultSet rs = ps.executeQuery();
  39. BLOB blob = null;
  40. if(rs.next())
  41. {
  42. blob = (BLOB)rs.getBlob(1);
  43. }
  44. //4. 使用字节流将待入库的文件写入到blob中
  45. File file = new File("D://iriver//sample1.bmp");
  46. FileInputStream fin = new FileInputStream(file);
  47. byte[] temp = new byte[fin.available()];
  48. fin.read(temp);
  49. OutputStream out = blob.getBinaryOutputStream();
  50. out.write(temp);
  51. fin.close();
  52. out.close();
  53. //5. 向数据库中写入数据
  54. sql = "update user_info set image = ? where user_id = ?";
  55. ps = conn.prepareStatement(sql);
  56. ps.setBlob(1, blob);
  57. ps.setInt(2, 1);
  58. ps.executeUpdate();
  59. conn.commit();
  60. } catch (Exception e)
  61. {
  62. e.printStackTrace();
  63. }
  64. }
  65. }

Oracle数据库BLOB字段的存取的更多相关文章

  1. 对oracle数据库Blob字段的操作

    java实体类 定义类型 byte[] private byte[] str_blob hibernate映射文件类型oracle.sql.BLOB <property name="s ...

  2. C# winform 窗体应用程序之图片上传Oracle数据库保存字段BLOB

    C# winform 窗体应用程序之图片上传Oracle数据库保存字段BLOB 我用的数据库是Oracle,就目前来看,许多数据库现在都倾向于Oracle数据库,对ORACLE数据库基本的操作也是必须 ...

  3. sybase数据库和oracle数据库中字段中含有换行符的解决办法

    最近在做数据库从sybase到oracle的迁移工作,sybase数据库表bcp导出后,通过sqlldr导入到oracle数据库,然后oracle数据库通过spool按照sybase数据库bcp的格式 ...

  4. oracle数据库调整字段顺序

    oracle数据库调整字段顺序 https://blog.csdn.net/xiaobaixie/article/details/77892034

  5. php oracle数据库NCOLB字段ORA-01704

    php oracle数据库NCOLB字段ORA-01704 对clob更新  ORA-01704: 字符串文字太长 解决办法:把字符赋值给一个变量,然后赋值update语句 declarev_clob ...

  6. FIREDAC保存ORACLE的BLOB字段数据

     FIREDAC默认识别ORACLE的BLOB字段为HUGEBLOB,需要将HBLOB映射为BLOB,才可以保存ORACLE的BLOB字段的数据.

  7. Oracle数据库中字段定义为Char类型,Hibernate用该字段进行动态绑定参数查询,获取不到结果的问题

    一.问题背景 产生环境:oracle数据库,hibernate操作 定义了一个表 create table STORE_INFORMATION ( id CHAR(32) not null, name ...

  8. Oracle数据库clob字段导出为sql insert插入语句

    oracle数据库的clob字段导出为sql insert插入语句可以分三种情况:1,clob没有换行符:2,clob有换行符但不以分号结尾:3,clob有换行符并且以分号结尾. clob没有换行符使 ...

  9. java读取写入oracle的blob字段工具类

    import com.hzunitech.fxgk.sys.model.UtFileData;import com.jfinal.kit.PathKit;import com.jfinal.plugi ...

随机推荐

  1. 微软雅黑 在css里怎么写

    1.首先要了解css中是如何控制字体的. font:在一个声明中设置所有字体属性: font有以下几个属性: font-style:字体样式 font-variant:字体异体 font-weight ...

  2. 一个大数据的demo

    package test.admin; import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.Fil ...

  3. JSTL配置

    1.下载jakarta-taglibs-standard-1.1.2.zip(在Weblogic中必须下载1.0版http://jakarta.apache.org/site/downloads/do ...

  4. Java和C++的虚函数的异同

    参考博客:点我 要点:Java中的普通函数默认为虚函数,因此动态绑定的行为是默认的,而C++必须将方法声明为虚函数(virtual关键字),执行时才会进行动态绑定,详细区别可参考代码以及注释. 代码大 ...

  5. 当窗体获得焦点时禁用max快捷键

    最近一段时间一直在MXS里用dotnet写界面...写的各种头晕眼花... 过程中遇到了 TextBox 控件输入时 与max快捷键冲突的问题. 解决办法是 用 MaxTextBox 控件替换,今天请 ...

  6. (转) How to Train a GAN? Tips and tricks to make GANs work

    How to Train a GAN? Tips and tricks to make GANs work 转自:https://github.com/soumith/ganhacks While r ...

  7. Python之路,day10-Python基础

    一.进程进程:一个程序要运行时所需的所有资源的集合 进程是资源的集合,相当于一个车间 一个进程至少需要一个线程,这个线程为主线程 一个进程里可以有多个线程 cpu cores越多,代表着你可以真正并发 ...

  8. cellmap for iphone

    说明:Cellmap的Iphone版本已经上架APP Store. 如需下载,可以登陆app store,然后搜索cellmap进行下载. 或者直接登陆以下地址下载: https://itunes.a ...

  9. 得到APP【每天听本书】微信交流群(每天更新)

    得到APP[每天听本书]微信交流群,每天更新下载学习资料 添加个人微信号:zhidu10000 进入微信群. “坚持每天读一本书,每天进步1.01,每年进步37.8倍” 2016年书单合辑点此链接,查 ...

  10. 第一章 数据库概述、MySQL的安装和配置

      第一章 数据库概述.MySQL的安装和配置   1.为什么要使用数据库 最早是纸质文件来存储数据 缺点:不易保存,占用空间大 计算机出现以后,采用软件来进行保存(excel) 缺点:容易损坏 文件 ...