转载自:http://blog.csdn.net/thc1987/article/details/3972201

存入操作

  1. /*
  2. ---------------表结构------------
  3. 表名:student2
  4. +--------+-------------+------+-----+---------+-------+
  5. | Field  | Type        | Null | Key | Default | Extra |
  6. +--------+-------------+------+-----+---------+-------+
  7. | id     | int(4)      | NO   | PRI | NULL    |       |
  8. | name   | varchar(20) | YES  |     | NULL    |       |
  9. | stupic | blob        | YES  |     | NULL    |       |
  10. +--------+-------------+------+-----+---------+-------+
  11. */
  12. package com.ibm.jdbc;
  13. import java.io.*;
  14. import java.sql.*;
  15. public class StoreBLOB {
  16. public static void main(String[] args) {
  17. //连接MySQl数据库
  18. Connection con=DBManager.getConnection();
  19. PreparedStatement ps=null;
  20. InputStream in=null;
  21. try {
  22. //从本地硬盘读取一张读片
  23. in=new FileInputStream("d:/111.jpg");
  24. ps=con.prepareStatement("insert into student2 values(?,?,?)");
  25. ps.setInt(1,2);
  26. ps.setString(2, "Tom");
  27. ps.setBinaryStream(3, in, in.available());
  28. ps.executeUpdate();
  29. } catch (IOException e) {
  30. // TODO Auto-generated catch block
  31. e.printStackTrace();
  32. }catch (SQLException e) {
  33. // TODO Auto-generated catch block
  34. e.printStackTrace();
  35. }
  36. finally
  37. {
  38. try {
  39. //关闭流
  40. if(in!=null) in.close();
  41. } catch (IOException e) {
  42. // TODO Auto-generated catch block
  43. e.printStackTrace();
  44. }
  45. //关闭相关连接
  46. DBManager.close(ps, con);
  47. }
  48. }
  49. }

取出操作

    1. package com.ibm.jdbc;
    2. import java.sql.*;
    3. import java.io.*;
    4. public class GetBLOB {
    5. public static void main(String[] args) {
    6. Connection con=DBManager.getConnection();
    7. Statement st=null;
    8. ResultSet rs=null;
    9. InputStream in=null;
    10. OutputStream out=null;
    11. try {
    12. st=con.createStatement();
    13. rs=st.executeQuery("select stupic from student2 where id=2");
    14. rs.next();  //将光标指向第一行
    15. //从rs中读取stupic放进InputStream对象中
    16. in=rs.getBinaryStream("stupic");
    17. //申明byte数组,用来存放图片流
    18. byte[] b=new byte[40000];
    19. in.read(b); //从InputStream对象中读取数据放进byte数组中
    20. //实例化OutputStream对象,在D盘创建一个图片文件
    21. out=new FileOutputStream("d:/222.jpg");
    22. //将文件输出,内容则为byte数组里面的数据
    23. out.write(b);
    24. out.flush();
    25. } catch (SQLException e) {
    26. // TODO Auto-generated catch block
    27. e.printStackTrace();
    28. }
    29. catch (IOException e) {
    30. // TODO Auto-generated catch block
    31. e.printStackTrace();
    32. }
    33. finally
    34. {
    35. try {
    36. if(in!=null)
    37. in.close();
    38. if(out!=null)
    39. out.close();
    40. } catch (IOException e) {
    41. // TODO Auto-generated catch block
    42. e.printStackTrace();
    43. }
    44. DBManager.close(rs, st, con);//关闭相关连接
    45. }
    46. }
    47. }

Java实现MySQL图片存取操作的更多相关文章

  1. Java实现对Mysql的图片存取操作

    1.MySQL中的BLOB类型 Mysql中可以存储大文件数据,一般使用的BLOB对象.如图片,视频等等. BLOB是一个二进制大对象,可以容纳可变数量的数据.因为是二进制对象,所以与编码方式无关.有 ...

  2. Java连接MySQL数据库及操作

    Java操作MySQL数据库,需要驱动mysql-connector-java 来进行操作,去下载对应的jar包   一.导入需要的jar包 我用的是maven对包进行管理,在maven中添加如下内容 ...

  3. JAVA对MySQL数据库的操作

    一.导包: 使用JDBC连接MySQL数据库时,首先需要导入一个第三方的JAR包(点击下载),下载解压得到一个JAR包,并导入到JAVA项目中,如下图: 二.DBHelper类: 代码如下: impo ...

  4. 在Jena框架下基于MySQL数据库实现本体的存取操作

    在Jena框架下基于MySQL数据库实现本体的存取操作 转自:http://blog.csdn.net/jtz_mpp/article/details/6224311 最近在做一个基于本体的管理系统. ...

  5. sqlite3的图片的(二进制数据)存取操作

    sqlite3的图片的(二进制数据)存取操作   前言 上篇介绍了sqlite3的一些常用插入操作方法和注意事项,在实际项目中遇到了图片缓存的问题,由于服务器不是很稳定,且受到外界环境的干扰(例如断电 ...

  6. Java连接MySQL数据库及简单操作代码

    1.Java连接MySQL数据库 Java连接MySql需要下载JDBC驱动MySQL-connector-java-5.0.5.zip(举例,现有新版本).然后将其解压缩到任一目录.我是解压到D盘, ...

  7. Java数据库连接--JDBC基础知识(操作数据库:增删改查)

    一.JDBC简介 JDBC是连接java应用程序和数据库之间的桥梁. 什么是JDBC? Java语言访问数据库的一种规范,是一套API. JDBC (Java Database Connectivit ...

  8. 让Java和MySQL连接起来

    Java 连接 MySQL 需要驱动包,可以下载菜鸟教程提供的 jar 包:http://static.runoob.com/download/mysql-connector-java-5.1.39- ...

  9. java 连接 MySQL

    java 连接 MySQL 1.准备工作 需要下载的工具: MySQL:http://www.mysql.com/downloads/ MySQL的可视化工具SQLyog:https://www.we ...

随机推荐

  1. 转:windbg调试堆

    转:http://www.cnblogs.com/dsky/archive/2013/05/15/3079363.html 简评: 代码中采用malloc/free进行堆申请,实际调用的仍然是Heap ...

  2. 第K短路模板【POJ2449 / 洛谷2483 / BZOJ1975 / HDU6181】

    1.到底如何求k短路的? 我们考虑,要求k短路,要先求出最短路/次短路/第三短路……/第(k-1)短路,然后访问到第k短路. 接下来的方法就是如此操作的. 2.f(x)的意义? 我们得到的f(x)更小 ...

  3. Java数组(int为例)

    Java数组(int为例) 定义:相同数据类型的数据的组合,是一种引用类型,是一个对象,存在堆里. 数组初始化:int[] scores1 = new int[]{72,90,59};//静态初始化: ...

  4. Luogu P4148 简单题(K-D Tree)

    题面 题解 因为强制在线,所以我们不能$cdq$分治,所以考虑用$KDT$,$KDT$维护一个矩阵,然后询问的时候如果当前矩形在询问区间内,直接记贡献,否则判断当前点是否在矩阵内,然后左右分别递归下去 ...

  5. Flask实战第50天:cms添加轮播图的模态对话框制作

    编辑cms_banners.html, 在{% block main_content%}中加上表给内容如下 {% block main_content %} <table class=" ...

  6. 离线情报分析工具CaseFile

    离线情报分析工具CaseFile   CaseFile是Maltego的姊妹工具,功能非常类似于Maltego.CaseFile主要针对数据进行离线分析,缺少Maltego的数据采集功能.它可以导入各 ...

  7. ubuntu问题集锦

    我使用的是ubuntu 14.04 用UltraIOS 制作镜像安装的  ubuntu 问题1:闪屏问题以及文字显示不全 解决方案:重装显卡驱动 解决过程:http://my.oschina.net/ ...

  8. POJ2505 A multiplication game 博弈论 找规律

    http://poj.org/problem?id=2505 感觉博弈论只有找规律的印象已经在我心中埋下了种子... 题目大意:两个人轮流玩游戏,Stan先手,数字 p从1开始,Stan乘以一个2-9 ...

  9. hdu 2955 Robberies(概率背包)

    Robberies Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total S ...

  10. BZOJ 4025 二分图(时间树+并查集)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=4025 [题目大意] 给出一张图,有些边只存在一段时间,问在一个每个时间段, 这张图是否 ...