转载自: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. win 10 下面安装 mysql-8.0.12-winx64 的过程

    win 10 下面安装 mysql-8.0.12-winx64 的过程 1.官网下载 mysql 2.解压到你要安装的目录 3.在mysql目录D:\Programming\mysql-8.0.12- ...

  2. 【java回调】同步/异步回调机制的原理和使用方法

    回调(callback)在我们做工程过程中经常会使用到,今天想整理一下回调的原理和使用方法. 回调的原理可以简单理解为:A发送消息给B,B处理完后告诉A处理结果.再简单点就是A调用B,B调用A. 那么 ...

  3. NetCore项目的部署

    NetCore项目和以前的AspNet项目在部署上有很大的不同,因为NetCore是跨平台的 NetCore支持Kestrel和IIS两种方式,看代码的11行和14行 using System.IO; ...

  4. Hive 空指针(NPE)异常

    空指针NullPointerException 1 Hive之前的一些BUG [HIVE-9430] - NullPointerException on ALTER TABLE ADD PARTITI ...

  5. JZYZOJ1502 [haoi2008]下落的圆盘 计算几何 贪心

    http://172.20.6.3/Problem_Show.asp?id=1502这种题用了快一天才写出来也是真的辣鸡.主要思路就是计算一下被挡住的弧度然后对弧度进行贪心.最开始比较困扰的是求弧度值 ...

  6. Codeforces Testing Round 14

    A:The Way to Home link:http://codeforces.com/contest/910/problem/A 题面:有每次最大跳跃距离d,只有一部分的点可以落脚,求最少几步达到 ...

  7. [CODECHEF]TREECNT2

    题意:一棵带边权的树,边权可单边修改,问初始时和每次修改后有多少条路径$\gcd=1$ 首先考虑用反演求答案,设$f(n)$为路径$\gcd=n$的路径条数,$g(n)$为路径$\gcd$是$n$倍数 ...

  8. 【组合计数】UVA - 11538 - Chess Queen

    考虑把皇后放在同一横排或者统一纵列,答案为nm(m-1)和nm(n-1),显然. 考虑同一对角线的情况不妨设,n<=m,对角线从左到右依次为1,2,3,...,n-1,n,n,n,...,n(m ...

  9. 【组合数】【乘法逆元】 Codeforces Round #404 (Div. 2) D. Anton and School - 2

    http://codeforces.com/blog/entry/50996 官方题解讲得很明白,在这里我复述一下. 枚举每个左括号,考虑计算一定包含其的简单括号序列的个数,只考虑其及其左侧的左括号, ...

  10. 2016.4.3 动态规划NOI专练 王老师讲课整理

    1.6049:买书 总时间限制:  1000ms 内存限制:  65536kB 描述 小明手里有n元钱全部用来买书,书的价格为10元,20元,50元,100元. 问小明有多少种买书方案?(每种书可购买 ...