在MySQL中存儲大文件


我們的目標:把一首mp3保存到MySQL數據庫中!
  由於MySQL默認當存入的數據太大時會拋異常,所以應在my.ini中添加如下配置!max_allowed_packet=10485760,這樣,可以最大存入一個10M的數據(當然可以設置更大)

  MySQL使用如下四種類型來處理文本大數據:
    類型           長度
    tinytext         28--1B(256B)
    text           216-1B(64K)
    mediumtext       224-1B(16M)
    longtext         232-1B(4G)

我們建立如下表:

CREATE TABLE tab_bin( id INT     PRIMARY KEY AUTO_INCREMENT, filename VARCHAR(100), data MEDIUMBLOB );

 向數據庫中插入文件核心代碼:

con = JdbcUtils.getConnection(); String sql = "insert into tab_bin(filename,data) values(?, ?)"; pstmt = con.prepareStatement(sql); pstmt.setString(1, "a.jpg"); InputStream in = new FileInputStream("f:\\a.jpg");//得到一個輸入流對象
pstmt.setBinaryStream(2, in);//為第二個參數賦值為流對象
pstmt.executeUpdate();

 從數據庫中取出文件核心代碼:

con = JdbcUtils.getConnection(); String sql = "select filename,data from tab_bin where id=?"; pstmt = con.prepareStatement(sql); pstmt.setInt(1, 1); rs = pstmt.executeQuery(); rs.next(); String filename = rs.getString("filename"); OutputStream out = new FileOutputStream("F:\\" + filename)//使用文件名來創建輸出流對象;
InputStream in = rs.getBinaryStream("data")//讀取輸入流對象;
IOUtils.copy(in, out)//把in中的數據寫入到out中;
out.close();

 第二種方法:

 向數據庫中插入文件核心代碼:

//存數據
con = JdbcUtils.getConnection(); String sql = "insert into tab_bin(filename,data) values(?, ?)"; pstmt = con.prepareStatement(sql); pstmt.setString(1, "a.jpg"); File file = new File("f:\\a.jpg"); byte[] datas = IOUtils.getBytes(file);//獲取文件中的數據
Blob blob = new SerialBlob(datas);//創建Blob對象
pstmt.setBlob(2, blob);//設置Blob類型的參數
pstmt.executeUpdate(); //取數據
con = JdbcUtils.getConnection(); String sql = "select filename,data from tab_bin where id=?"; pstmt = con.prepareStatement(sql); pstmt.setInt(1, 1); rs = pstmt.executeQuery(); rs.next(); String filename = rs.getString("filename"); File file = new File("F:\\" + filename) ; Blob blob = rs.getBlob("data"); byte[] datas = blob.getBytes(0, (int)file.length()); IOUtils.writeByteArrayToFile(file, datas);


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM