相较于Oracle,MySQL作为一个轻量级的开源的数据库,可谓是大大简化了我们的操作。这次我就来写一个关于数据库存入图片,获取图片的例子吧,也为了今后的复习使用。(我们一般采取存入路径的方式,而不是直接存储字节的方式,毕竟读取的时候还要通过字节读取,并做一些转换,这真的是太麻烦了,但是咧,这次就来个麻烦的吧,咱们用字节的方式)

首先我们需要在MySQL数据库中创建好我们所需要的表

,下面就是正式的编码了,我们需要一个数据库专用类,用于对数据库的一些操作,我称之为DBUtils

package DBUtils;

import java.sql.DriverManager;
import java.sql.SQLException;

import com.mysql.jdbc.*;
public class ConnectionToMySQL {

    private String DRIVER,name,password;

    public ConnectionToMySQL() {
        // TODO Auto-generated constructor stub
    }

    public static void main(String []args){
        getConnection();
    }

    public static Connection getConnection(){
        Connection conn=null;
        try {
            String DRIVER="com.mysql.jdbc.Driver";
            String url="jdbc:mysql://localhost:3306/tiger";
            Class.forName(DRIVER);
            conn=(Connection) DriverManager.getConnection(url, "root", "mysql");

            System.out.println("Succeed in Connect to your Database!");

        } catch (ClassNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return conn;
    }

}

很明显,接下来就是往数据库存入我们的图片了,代码如下,

import java.sql.SQLException;

import DBUtils.ConnectionToMySQL;

import com.mysql.jdbc.PreparedStatement;

public class SaveImage {

    public SaveImage() {
        // TODO Auto-generated constructor stub
    }

    public static String insertImage(){
        String flag="";
        String sql="insert into tiger.ImageTable values(?,?)";
        try {
            PreparedStatement ps=(PreparedStatement) ConnectionToMySQL.getConnection()
                    .prepareStatement(sql);
            ps.setString(1, "mySelf");
            ps.setString(2, "image1");

            ps.execute();
            if(ps.execute()){
                flag="成功插入数据!!!";
            }else{
                flag="抱歉,未能 成功插入数据!!!";
            }
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return flag;
    }

}

再然后就是读取图片,或者写入到本地文件下(请注明路径和文件名称,因为等会我们要使用哟),代码如下:

package image;

import java.io.FileOutputStream;
import java.io.InputStream;
import java.sql.ResultSet;
import java.sql.SQLException;

import DBUtils.ConnectionToMySQL;

import com.mysql.jdbc.Blob;
import com.mysql.jdbc.PreparedStatement;

public class GetImage {

    public GetImage() {
        // TODO Auto-generated constructor stub
    }

    /**
     * 这二个方法仅仅是测试我们的数据库中到底有什么值,并没有什么大的用处
     * @return
     */
    public static String getAndRead(){
        String flag="";
        String sql="select * from ImageTable";
        try{
            PreparedStatement ps=(PreparedStatement) ConnectionToMySQL.getConnection()
                .prepareStatement(sql);
            ResultSet rs=ps.executeQuery();

            while(rs.next()){
                System.out.print(rs.getString("name")+"\t");
                System.out.println(rs.getString("image"));
            }
        }catch(SQLException e){
            e.printStackTrace();
        }catch(Exception ee){
            ee.printStackTrace();
        }

        return flag;
    }

    /**
     * 读取数据库中的blob类型的图片文件,并存储到本地
     * @throws SQLException
     */
    public static void SetBlobToFile() throws SQLException{
        InputStream bb=null;
        String sql="select image from ImageTable where name='mySelf';";
        try{
            PreparedStatement ps=(PreparedStatement) ConnectionToMySQL.getConnection()
                .prepareStatement(sql);
            ResultSet rs=ps.executeQuery();
            rs.next();
            bb=rs.getBinaryStream("image");
            FileOutputStream os = new FileOutputStream("F:\\target"+".jpg");
            byte[] buff = new byte[1024];
            os.write(buff);
            rs=null;
            System.out.println("图片文件写入本地成功!");
        }catch(SQLException e){
            e.printStackTrace();
        }catch(Exception ee){
            ee.printStackTrace();
        }
    }

}

下面开始进行整体的存储吧:

package image;

import java.sql.SQLException;

public class Test {

    public Test() {
        // TODO Auto-generated constructor stub
    }

    public static void main(String[] args) throws SQLException {
        // TODO Auto-generated method stub
        System.out.println("程序开始!");
        SaveImage.insertImage();
        GetImage.getAndRead();
        GetImage.SetBlobToFile();
        System.out.println("程序结束!");
    }

}

运行结果:

Succeed in Connect to your Database!

Doge doge.gif

mySelf image1.jpg

Succeed in Connect to your Database!

图片文件写入本地成功!

程序结束!

好了,完事具备,就差对我们的成果进行检验了,下面请看一个Demo,就是使用我们从数据库中获取到的图片的使用案例,代码如下:

package image;

import java.awt.BorderLayout;

import javax.swing.Icon;
import javax.swing.ImageIcon;
import javax.swing.JFrame;
import javax.swing.JLabel;

public class PictureInstance extends JFrame {

    private JLabel label;

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        new PictureInstance();
    }

    public PictureInstance(){
        label=new JLabel();

        this.setSize(500,400);
        this.setVisible(true);
        this.setLocationRelativeTo(null);
        this.setDefaultCloseOperation(EXIT_ON_CLOSE);

        this.add(label,BorderLayout.CENTER);
        label.setIcon(new ImageIcon("F:\\target.jpg"));
    }

}

下面就是运行的结果了,



好了,大概就是这样了。虽然这种方式会导致数据的部分丢失,而且方式繁琐冗杂。个人建议使用路径的方式存储以及读取图片更为合理,且更为方便高效。

MySQL数据库写入图片并读取图片显示到JLabel上的详解的更多相关文章

  1. MySQL数据库INSERT、UPDATE、DELETE以及REPLACE语句的用法详解

    本篇文章是对MySQL数据库INSERT.UPDATE.DELETE以及REPLACE语句的用法进行了详细的分析介绍,需要的朋友参考下   MySQL数据库insert和update语句引:用于操作数 ...

  2. 转载:MySQL数据库INSERT、UPDATE、DELETE以及REPLACE语句的用法详解

    转自:http://www.jb51.net/article/39199.htm 本篇文章是对MySQL数据库INSERT.UPDATE.DELETE以及REPLACE语句的用法进行了详细的分析介绍, ...

  3. 历史上的今天mysql数据库包含详情分类以及图片

    历史上的今天mysql数据库包含详情分类以及图片 https://item.taobao.com/item.htm?spm=a2oq0.12575281.0.0.50111debo71iaJ& ...

  4. .NET 5/.NET Core使用EF Core 5连接MySQL数据库写入/读取数据示例教程

    本文首发于<.NET 5/.NET Core使用EF Core 5(Entity Framework Core)连接MySQL数据库写入/读取数据示例教程> 前言 在.NET Core/. ...

  5. saltstack自动化运维系列④之saltstack的命令返回结果mysql数据库写入

    saltstack自动化运维系列④之saltstack的命令返回结果mysql数据库写入salt的返回值写入mysql数据库:可参考:https://docs.saltstack.com/en/lat ...

  6. Mysql数据库写入数据速度优化

    Mysql数据库写入数据速度优化 1)innodb_flush_log_at_trx_commit 默认值为1:设置为0,可以提高写入速度.  值为0:提升写入速度,但是安全方面较差,mysql服务器 ...

  7. 访问远程mysql数据库,出现报错,显示“1130 - Host'xxx.xxx.xxx.xxx' is not allowed to connect to this MySQL server“

    在使用Navicat for MySQl访问远程mysql数据库,出现报错,显示“1130 - Host'xxx.xxx.xxx.xxx' is not allowed to connect to t ...

  8. MVC图片上传详解 IIS (安装SSL证书后) 实现 HTTP 自动跳转到 HTTPS C#中Enum用法小结 表达式目录树 “村长”教你测试用例 引用provinces.js的三级联动

    MVC图片上传详解   MVC图片上传--控制器方法 新建一个控制器命名为File,定义一个Img方法 [HttpPost]public ActionResult Img(HttpPostedFile ...

  9. Newtonsoft.Json C# Json序列化和反序列化工具的使用、类型方法大全 C# 算法题系列(二) 各位相加、整数反转、回文数、罗马数字转整数 C# 算法题系列(一) 两数之和、无重复字符的最长子串 DateTime Tips c#发送邮件,可发送多个附件 MVC图片上传详解

    Newtonsoft.Json C# Json序列化和反序列化工具的使用.类型方法大全   Newtonsoft.Json Newtonsoft.Json 是.Net平台操作Json的工具,他的介绍就 ...

随机推荐

  1. 转:linux/unix命令行终端的光标及字符控制快捷键

    from:http://linux.chinaunix.net/techdoc/system/2007/11/23/973027.shtml 在使用linux/unix的命令行终端时,有时候会碰到键盘 ...

  2. Linux服务器搭建相关教程链接整理

    Linux: Linux 教程 | 菜鸟教程 linux下如何添加一个用户并且让用户获得root权限 - !canfly - 博客园 Git: 在 Linux 下搭建 Git 服务器 - 黄棣-dee ...

  3. [多线程] 生产者消费者模型的BOOST实现

    说明 如果 使用过程中有BUG 一定要告诉我:在下面留言或者给我邮件(sawpara at 126 dot com) 使用boost::thread库来实现生产者消费者模型中的缓冲区! 仓库内最多可以 ...

  4. 安卓热修复之AndFIX

    我致力于最新的前沿安卓技术分析和使用教学,不打算将很多很深的东西,因为有多少人愿意沉下你的心境去学习难点?我一般只会简单提及.文字错漏在所难免还希望同学们喜欢 热修复介绍 热修复是什么? 如果你一个项 ...

  5. Appium webdriver的capabilities配置

    Capabilities是由客户端发送给Appium服务器端的用来告诉服务器去启动哪种我们想要的会话的一套键值对集合.当中也有一些键值对是用来在自动化的过程中修改服务器端的行为方式. 必填的项目: d ...

  6. [Python] 图像简单处理(PIL or Pillow)

    前几天弄了下django的图片上传,上传之后还需要做些简单的处理,python中PIL模块就是专门用来做这个事情的. 于是照葫芦画瓢做了几个常用图片操作,在这里记录下,以便备用. 这里有个字体文件,大 ...

  7. JAVA面向对象-----多态

    多态的概述 1:什么是多态 一个对象的多种状态 (老师)(员工)(儿子) 教师 a =老钟; 员工 b= 老钟; 2:多态体现 1:Father类 1:非静态成员变量x 2:静态成员变量y 3:非静态 ...

  8. Retrofit2.0 ,OkHttp3完美同步持久Cookie实现免登录(二)

    原文出自csdn: http://blog.csdn.net/sk719887916/article/details/51700659: 通过对Retrofit2.0的<Retrofit 2.0 ...

  9. 【移动开发】Context类bindService()参数

    bindService()是Context的一个方法,它是抽象的.函数原型的代码如下:(android 2.3.3) /** * Connect to an application service, ...

  10. JVM常量池和八种基本数据及字符串

    迄今为止看到的对常量池和字符串最为透彻的解释,赞一个! 常量池(constant_pool)指的是在编译期被确定,并被保存在已编译的.class文件中的一些数据.它包括了关于类.方法.接口等中的常量, ...