JDBC--(8)数据库存储图片、从数据库中获取图片

JDBC 存储图片

数据库当中的BLOB
存储图片、音频、视频等多媒体信息
以二进制流的形式
真正开发中
不会把二进制的文件存放在数据库当中
把文件存储的路径保存在数据库当中,以后再取出路径,到该路径下读取信息
BLOB类型
TINYBLOB 255个字节
BLOB 65535字节
MEDIUMBLOB 16M
LONGBLOB 4G

操纵:

  1. 在表中添加一个字段,类型选择为blob类型

  2. 通过代码存入一张图片到数据库当中

  3. 从数据库当中把存储的图片取出

在这里插入图片描述

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);
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值