JDBC 存储图片
数据库当中的BLOB
存储图片、音频、视频等多媒体信息
以二进制流的形式
真正开发中
不会把二进制的文件存放在数据库当中
把文件存储的路径保存在数据库当中,以后再取出路径,到该路径下读取信息
BLOB类型
TINYBLOB
255个字节
BLOB
65535字节
MEDIUMBLOB
16M
LONGBLOB
4G
操纵:
-
在表中添加一个字段,类型选择为blob类型
-
通过代码存入一张图片到数据库当中
-
从数据库当中把存储的图片取出
package com.iris.jdbc.test;
import java.io.FileInputStream;
import java.sql.Connection;
import java.sql.PreparedStatement;
import com.iris.jdbc.util.JDBCUtil;
public class BlobTest {
public static void main(String[] args) throws Exception {
Connection conn = JDBCUtil.getConn();
String sql = "insert into student (img) values(?)";
PreparedStatement ps = conn.prepareStatement(sql);
//读取磁盘当中的文件,转成计算机能够识别的二进制
//输入流 InputStream
// 将电脑当中的文件放到程序当中(是以二进流)输入流
FileInputStream in = new FileInputStream("f:/截图/引用类型_地址传递/5.png");
ps.setBlob(1,in);
ps.executeUpdate();
JDBCUtil.close(conn, ps, null);
}
}
JDBC 从数据库中获取图片
package com.iris.jdbc.test;
import java.io.InputStream;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.sql.Blob;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import com.iris.jdbc.util.JDBCUtil;
public class GetPictureTest {
public static void main(String[] args) throws Exception {
//连接数据库
Connection conn = JDBCUtil.getConn();
String sql = "select * from student where id =?";
PreparedStatement ps = conn.prepareStatement(sql);
ps.setInt(1, 1);
ResultSet res = ps.executeQuery();
if(res.next()) {
//获取图片
Blob blob = res.getBlob("img");
//获取图片二进制流
InputStream in = blob.getBinaryStream();
//把程序当中的文件写到磁盘
Files.copy(in, Paths.get("f:/截图/mysql.png"));
}
JDBCUtil.close(conn, ps, res);
}
}