>>分享Java编程技术,对《Java面向对象编程》等书籍提供技术支持 书籍支持  卫琴直播  品书摘要  在线测试  资源下载  联系我们
发表一个新主题 开启一个新投票 回复文章 您是本文章第 31547 个阅读者 刷新本主题
 * 贴子主题:  通过Java编程向数据库存取图片 回复文章 点赞(0)  收藏  
作者:Jacky    发表时间:2018-03-22 22:10:06     消息  查看  搜索  好友  邮件  复制  引用

我们要做的是将一张图片存入Mysql中,在Mysql中用Blob 来存储图片和音频等大的数据项.Blob 按其容量可分为四种,分别为:tinyblob,blob ,mediumblob, longblob.他们的大小分别为:256B,64KB,16MB,4GB.除了容量不同外,这四种的用法一个样.我们这次将用Blob.

首先来创建我们的数据库,

create database  Image;
use Image;

create table country (

id int primary key auto_increment,

name varchar(30),

flag blob,

description varchar(255)

);

数据库创建完毕,下面是Java 的程序代码,它实现的功能是从一个目录中读入一张图片(china.gif) ,然后在把它输出在另一个目录中(1.gif).

*****************************************************************************************************

import java.sql.*;
import java.io.*;

public class TestImage {
private static final String URL = "jdbc:mysql://localhost/Image?user=root&password=root&useUnicode=true";
private Connection conn = null;
private PreparedStatement pstmt = null;
private ResultSet rs = null;
private File file = null;
private InputStream inputImage = null;
private OutputStream outputImage = null;

public void blobInsert(String infile) {
  try {
   Class.forName("com.mysql.jdbc.Driver");
   System.out.println("Driver loaded!");

   conn = DriverManager.getConnection(URL);
   System.out.println("Database connected!");

   pstmt = conn
     .prepareStatement("insert into Country (name,flag,description) values (?,?,?)");
   pstmt.setString(1, "china");

   file = new File(infile);
   try {
    inputImage = new FileInputStream(file);
   } catch (FileNotFoundException e) {

    e.printStackTrace();
   }
   pstmt.setBinaryStream(2, inputImage, (int) (file.length()));

   pstmt.setString(3, "A flag of China");
   pstmt.executeUpdate();
   System.out.println("commit successfully");
  } catch (ClassNotFoundException e) {

   e.printStackTrace();
  } catch (SQLException e) {
   e.printStackTrace();
  } finally {
   try {
    inputImage.close();
    pstmt.close();
    conn.close();
   } catch (Exception e) {
    e.printStackTrace();
   }
  }

}

public void readBolb(String path, int id) {
  InputStream is = null;
  byte[] buffer = new byte[4096];

  try {
   Class.forName("com.mysql.jdbc.Driver");
   System.out.println("Driver loaded!");

   conn = DriverManager.getConnection(URL);
   System.out.println("Database connected!");

   pstmt = conn
     .prepareStatement("select flag from Country where id =?");
   System.out.println("select ok");

   pstmt.setInt(1, id);
   rs = pstmt.executeQuery();

   rs.next();
   file = new File(path);
   if (!file.exists()) {
    try {
     file.createNewFile();
    } catch (IOException e) {

     e.printStackTrace();
    }

   }
   try {
    outputImage = new FileOutputStream(file);
    System.out.println(outputImage.toString());
   } catch (FileNotFoundException e) {

    e.printStackTrace();
   }

   Blob blob = rs.getBlob("flag");
   is = blob.getBinaryStream();
   try {
    System.out.println(is.available());
   } catch (IOException e2) {
    
    e2.printStackTrace();
   }
   try {
    System.out.println(is.available());
   } catch (IOException e1) {

    e1.printStackTrace();
   }

   int size = 0;
   try {
    while ((size = is.read(buffer)) != -1) {
     System.out.println(size);
     outputImage.write(buffer, 0, size);

    }
   } catch (IOException e) {

    e.printStackTrace();
   }

  } catch (ClassNotFoundException e) {

   e.printStackTrace();
  } catch (SQLException e) {

   e.printStackTrace();
  } finally {
   try {
    is.close();
    outputImage.close();
    pstmt.close();
    conn.close();
   } catch (Exception e) {
    e.printStackTrace();
   }
  }

}

public static void main(String[] args) {

  new TestImage().blobInsert("c://TDdownload//china.gif");
  new TestImage().readBolb("c://1.gif", 1);
}

}

程序执行完你将在相应的目录下看到一张输出的图片.同时在Mysql 客户端使用:select * from country;将显示一堆的乱麻,这就正常.说明图片已经存入Mysql 中.到次本次试验完毕!


程序猿的技术大观园:www.javathinker.net
  Java面向对象编程-->继承
  JavaWeb开发-->访问数据库(Ⅱ)
  JSP与Hibernate开发-->数据库事务的并发问题的解决方案
  Java网络编程-->基于MVC和RMI的分布式应用
  精通Spring-->Vue CLI脚手架工具
  Vue3开发-->Vue指令
  Java虚拟机安全性-class文件检验器
  整理收集的一些常用java工具类
  Java虚拟机(JVM)参数配置说明
  面向对象的七大原则,你知道几个?
  JDK14的新特性
  Java是如何实现自己的SPI机制的?
  HashMap中 get 和 put 操作的具体过程
  Java方法的嵌套与递归调用
  Java入门实用代码: List 列表中元素的替换
  Java入门实用代码:集合输出
  Java入门实用代码:字符串小写转大写
  Java入门实用代码:删除一个文件目录
  java实现PPT转化为PDF
  Eclipse中怎么一键去除java项目中的信息打印语句
  JDBC使用8.0驱动包连接mysql设置时区serverTimezone
  更多...
 IPIP: 已设置保密
楼主      
1页 0条记录 当前第1
发表一个新主题 开启一个新投票 回复文章


中文版权所有: JavaThinker技术网站 Copyright 2016-2026 沪ICP备16029593号-2
荟萃Java程序员智慧的结晶,分享交流Java前沿技术。  联系我们
如有技术文章涉及侵权,请与本站管理员联系。