亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Java > 正文

Java+MySql圖片數據保存與讀取的具體實例

2019-11-26 16:03:19
字體:
來源:轉載
供稿:網友

1.創建表:

復制代碼 代碼如下:

drop table if exists photo;
CREATE TABLE photo (
    id INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(100) COMMENT '名稱',
    photo blob COMMENT '照片'
)
ENGINE=InnoDB
DEFAULT CHARSET=utf8
COLLATE=utf8_general_ci;

 圖片在MySql中的數據存儲格式為blob類型;Blob是一個可以存儲二進制文件的容器。

2.編寫圖片流數據存取的工具類:

復制代碼 代碼如下:

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;

public class ImageUtil {
    private static File file = null;

    /**
     * 從本地文件讀取圖像的二進制流
     *
     * @param infile
     * @return
     */
    public static FileInputStream getImageByte(String infile) {
        FileInputStream imageByte = null;
        file = new File(infile);
        try {
            imageByte = new FileInputStream(file);
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        }
        return imageByte;
    }

    /**
     * 將圖片流讀出為圖片
     *
     * @param inputStream
     * @param path
     */
    public static void readBlob(InputStream inputStream, String path) {
        try {
            FileOutputStream fileOutputStream = new FileOutputStream(path);
            byte[] buffer = new byte[1024];
            int len = 0;
            while ((len = inputStream.read(buffer)) != -1) {
                fileOutputStream.write(buffer, 0, len);
            }
            inputStream.close();
            fileOutputStream.close();
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }

    }
}

3.將本地文件保存到數據庫

  需要添加MySql的數據庫驅動--mysql-connector-java-5.1.24-bin.jar

復制代碼 代碼如下:

import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;

public class ImageInsert {
    public static void main(String[] args) {
        try {
            Class.forName("com.mysql.jdbc.Driver").newInstance();
        } catch (InstantiationException e) {
            e.printStackTrace();
        } catch (IllegalAccessException e) {
            e.printStackTrace();
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
        String user = "root";
        String password = "root";
        String url = "jdbc:mysql://localhost:3306/test?characterEncoding=utf-8";
        Connection connection = null;
        try {
            connection = DriverManager.getConnection(url, user, password);
        } catch (SQLException e) {
            e.printStackTrace();
        }
        PreparedStatement preparedStatement = null;
        InputStream inputStream = null;
        inputStream = ImageUtil.getImageByte("D://temp//photo1.png");
        try {
            String sql = "insert into photo(id,name,photo) values(?,?,?)";
            preparedStatement = connection.prepareStatement(sql);
            preparedStatement.setInt(1, 1);
            preparedStatement.setString(2, "朱莉");
            preparedStatement.setBinaryStream(3, inputStream,
                    inputStream.available());
            preparedStatement.execute();
        } catch (SQLException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            try {
                if (inputStream != null)
                    inputStream.close();
            } catch (IOException e) {
                e.printStackTrace();
            } finally {
                try {
                    if (preparedStatement != null)
                        preparedStatement.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                } finally {
                    try {
                        connection.close();
                    } catch (SQLException e) {
                        e.printStackTrace();
                    }
                }
            }
        }

    }
}


4.從數據庫中讀取并生成圖片
復制代碼 代碼如下:

import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class ImageGet {
    public static void main(String[] args) {
        try {
            Class.forName("com.mysql.jdbc.Driver").newInstance();
        } catch (InstantiationException e) {
            e.printStackTrace();
        } catch (IllegalAccessException e) {
            e.printStackTrace();
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
        String user = "root";
        String password = "root";
        String url = "jdbc:mysql://localhost:3306/test?characterEncoding=utf-8";
        Connection connection = null;
        try {
            connection = DriverManager.getConnection(url, user, password);
        } catch (SQLException e) {
            e.printStackTrace();
        }
        Statement statement = null;
        ResultSet resultSet = null;
        InputStream inputStream = null;
        try {
            statement = connection.createStatement();
            String sql = "select p.photo from photo p where id = 1";
            resultSet = statement.executeQuery(sql);
            resultSet.next();
            inputStream = resultSet.getBinaryStream("photo");
            ImageUtil.readBlob(inputStream, "D://temp//photo2.png");
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            try {
                if (inputStream != null)
                    inputStream.close();
            } catch (IOException e) {
                e.printStackTrace();
            } finally {
                try {
                    if (resultSet != null)
                        resultSet.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                } finally {
                    if (statement != null)
                        if (statement != null)
                            try {
                                statement.close();
                            } catch (SQLException e) {
                                e.printStackTrace();
                            } finally {
                                if (connection != null)
                                    try {
                                        connection.close();
                                    } catch (SQLException e) {
                                        e.printStackTrace();
                                    }
                            }
                }
            }
        }

    }
}


5.Over!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
一区二区日韩精品| 神马国产精品影院av| 亚洲free性xxxx护士hd| 欧美精品少妇videofree| 国产精品网站视频| 久久天堂av综合合色| 国产精品视频免费观看www| 国产黑人绿帽在线第一区| 狠狠色狠狠色综合日日小说| 国产成人激情小视频| 欧美在线不卡区| 中文字幕少妇一区二区三区| 国产精品久久久久9999| 日韩一区二区av| 国产色综合天天综合网| 精品免费在线视频| 国产成人jvid在线播放| 91久热免费在线视频| 亚洲无限乱码一二三四麻| 亚洲视频在线观看| 原创国产精品91| 国产精品va在线播放我和闺蜜| 国产精品成人免费电影| 欧美激情亚洲自拍| 日韩美女中文字幕| 在线精品国产成人综合| 亚洲精品一区二区三区婷婷月| 亚洲午夜色婷婷在线| 欧美在线影院在线视频| 日韩中文在线中文网在线观看| 亚洲精品国产精品国自产在线| 性金发美女69hd大尺寸| 亚洲美腿欧美激情另类| 精品视频久久久久久| 国产精品影片在线观看| 国产精品69精品一区二区三区| 亚洲欧美成人精品| 国模精品视频一区二区| 亚洲欧美激情视频| 国产精品久久久久高潮| 91高清在线免费观看| 国产欧美精品日韩精品| 青草青草久热精品视频在线网站| 国产一区二区三区高清在线观看| 国产精品久久网| 亚洲男人天堂2023| 日韩欧美在线看| 亚洲国产欧美在线成人app| 91精品中国老女人| 国产精品美女主播在线观看纯欲| 国内精品久久久久影院 日本资源| 亚洲最大成人免费视频| 91麻豆国产语对白在线观看| 亚洲色图综合久久| 亚洲字幕一区二区| 亚洲欧美三级在线| 中文字幕国产日韩| 欧美大秀在线观看| 日韩av综合中文字幕| 久久天天躁狠狠躁夜夜av| 国产精品成人免费电影| 国内精久久久久久久久久人| 亚洲欧美日韩高清| 97在线看免费观看视频在线观看| 亚洲精品久久7777777| 国产经典一区二区| 午夜免费在线观看精品视频| 日韩中文字幕网址| 久久91精品国产91久久跳| 日韩成人中文电影| 91在线观看免费| www日韩中文字幕在线看| 国产在线视频一区| 色综合视频一区中文字幕| 亚洲高清福利视频| 欧美成人一区二区三区电影| 欧美日韩中国免费专区在线看| 欧美激情精品久久久久久| 国产日韩中文在线| 国产精品视频中文字幕91| 国产午夜精品一区二区三区| 91亚洲精品一区| 国产91精品久久久久| 午夜精品美女自拍福到在线| 亚洲视频网站在线观看| 国产精品自产拍在线观| 亚洲国产精彩中文乱码av在线播放| 91在线免费视频| 97视频免费在线观看| 国产精品黄色av| 人妖精品videosex性欧美| 九九热精品视频在线播放| 最近中文字幕mv在线一区二区三区四区| 欧美最猛性xxxxx(亚洲精品)| www.99久久热国产日韩欧美.com| 精品国产一区二区三区在线观看| 日韩一区二区三区在线播放| 欧美日韩国产成人| 欧美激情精品久久久久久久变态| 免费91麻豆精品国产自产在线观看| 91久久国产综合久久91精品网站| 亚洲国产欧美一区二区丝袜黑人| 日本精品视频在线| 中文在线资源观看视频网站免费不卡| 日韩免费观看在线观看| 国产精品盗摄久久久| 欧美性黄网官网| 久久99国产精品久久久久久久久| 亚洲精品电影在线观看| 日本欧美黄网站| 97高清免费视频| 国产成人亚洲精品| 亚洲一区二区福利| 国产精品丝袜白浆摸在线| 亚洲精品中文字幕有码专区| 久久中文字幕视频| 日本三级久久久| 亚洲91精品在线| 欧美精品久久久久久久久久| 精品久久久91| 久久免费国产精品1| 国产精品香蕉国产| 不卡在线观看电视剧完整版| 亚洲欧美制服综合另类| 国产成人精品电影| 成人国内精品久久久久一区| 亚洲白拍色综合图区| 久久频这里精品99香蕉| 欧美亚洲成人精品| 亚洲2020天天堂在线观看| 国产精品日日做人人爱| 亚洲男人天堂九九视频| 精品福利在线看| 亚洲精品视频在线播放| 国产精品av在线| 91禁外国网站| 国产丝袜高跟一区| 黄网站色欧美视频| 欧美一级高清免费| 日韩精品在线电影| 永久免费精品影视网站| 久久久久久久久久亚洲| 国产精品∨欧美精品v日韩精品| 亚洲精品福利在线| 久久久久久免费精品| 成人午夜高潮视频| 久久天天躁狠狠躁夜夜av| 亚洲欧美福利视频| 日日噜噜噜夜夜爽亚洲精品| 久久久爽爽爽美女图片| 正在播放欧美一区| 亚洲国产精品va在线看黑人动漫| 最新69国产成人精品视频免费| 亚洲女在线观看| 久久精品亚洲精品| 国产一区二区色| 久久国产天堂福利天堂| 动漫精品一区二区| 亚洲天堂男人的天堂| 欧美性在线观看| 国产综合福利在线| 国产婷婷成人久久av免费高清| 国产精品青青在线观看爽香蕉| 日韩资源在线观看|