把MP3保存到数据库中

时间:2022-03-09 17:43:39

使用JdbcUtils得到连接con

java.sql包下的Interface Blob----其实现类SerialBlob

Blob是一个可以存储二进制文件的容器。

BLOB常常是数据库中用来存储二进制文件的字段类型。

MySQL中,BLOB是个类型系列,包括TinyBlob,Blob,MediumBlob,LongBlob,这几个类型之间的唯一区别是在存储文件的最大 大小上不同。

类型   大小(单位:字节)

TinyBlob 最大  255

Blob 最大  65k

MediumBlob  中等 16M

LongBlob 最大 4G

所需数据库结构

把MP3保存到数据库中

 //把MP3保存到数据库中
@Test
public void fun() throws Exception{
Connection con=JdbcUtils.getConnection();
String sql="insert into tab_bin values(?,?,?)";
PreparedStatement pstmt=con.prepareStatement(sql);
pstmt.setInt(1, 1);
pstmt.setString(2, "Circus.mp3");
//需要得到blob
/*1.我们有的是文件,目标是Blob
* 2.先把文件变成byte[]
* 3.再使用byte[]创建Blob
* */
//把文件转换成byte[]
byte[] bytes=IOUtils.toByteArray(new FileInputStream("F:/CloudMusic/Circus.mp3")); Blob blob=new SerialBlob(bytes);
//设置参数
pstmt.setBlob(3, blob); pstmt.executeUpdate();
}

从数据库中读MP3数据,然后写到磁盘中

 @Test
public void fun2() throws Exception{
Connection con=JdbcUtils.getConnection();
System.out.println(con);
String sql="select * from tab_bin where filename=?";
PreparedStatement pstmt=con.prepareStatement(sql);
pstmt.setString(1, "Circus.mp3");
ResultSet rs= pstmt.executeQuery();
System.out.println("查询成功");
//获取rs中的名为data的数据----数据库中的名
if(rs.next()){
Blob blob=rs.getBlob("data");
/*把Blob变成硬盘上的文件
*
* 1.通过Blob得到输入流对象
* 2.自己创建输出流对象
* 3.把输入流的数据写入到输出流中
* */
InputStream in=blob.getBinaryStream();//读
//写
OutputStream out=new FileOutputStream("G:/金泰妍1.MP3");
IOUtils.copy(in, out);
}

IOUtils是一个类---封装了IO操作的相关类----提供了对流的操作

常用方法

copy这个方法可以拷贝流

copy(inputstream,outputstream)
copy(inputstream,writer)
copy(inputstream,writer,encoding)
copy(reader,outputstream)
copy(reader,writer)
copy(reader,writer,encoding)

copyLarge这个方法适合拷贝大的数据流,比如2G以上。

copyLarge(reader,writer) 默认会用1024*4的buffer来读取
copyLarge(reader,writer,buffer)

read从一个流中读取数据

read(inputstream,byte[])
read(inputstream,byte[],offset,length)
//offset是buffer的偏移值,length是读取的长度 read(reader,char[])
read(reader,char[],offset,length)

等等方法,见IOUtils类