91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何基于java向mysql數據庫中存取圖片

發布時間:2020-09-29 21:18:16 來源:腳本之家 閱讀:412 作者:西紅柿里沒有番茄 欄目:編程語言

這篇文章主要介紹了如何基于java向mysql數據庫中存取圖片,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

學mysql的時候都是做個表格,放的也都是文字內容,雖然我知道長篇的文章和圖片或者視頻的都是用過文件夾的方式存儲的,再講文件路徑存進數據庫中。但還是想試試直接往mysql數據庫中存取圖片。這里我用的是java語言和jdbc實現的

mysql數據庫中有一個類型是Blob類型,這是一個二進制類型,通常我們會將圖片或音像文件轉成二進制再存入數據庫中,Blob分為以下幾種:

  • TinyBlob 最大 255
  • Blob 最大 65K
  • MediumBlob 最大 16M
  • LongBlob 最大 4G

除了jdbc的連接以外,我們需要用到文件的輸入、輸出流。實現兩個方法,一個方法向數據庫中存圖像,另一個方法從數據庫中讀取圖像并存在電腦本地

import java.io.*;
import java.sql.*;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Scanner;


public class Database {


  //JDBC驅動名
  String JDBC_DRIVER = "com.mysql.jdbc.Driver";

  //數據庫URL:這里的tt是數據庫名稱
  String JDBC_URL = "jdbc:mysql://localhost:3306/daImage?useSSL=false&serverTimezone=UTC";

  //    數據庫的用戶名與密碼
  String USER = "root";
  String PASS = "admin123";

  //通過DriverManager類獲得該連接對象才能訪問數據庫
  Connection connection = null;

  //    通過Connection獲得該結果對象用于執行靜態的SQL語句
//  Statement statement = null;
  PreparedStatement preparedStatement = null;

  String path;
  FileInputStream fileInputStream;


  
  Database() {


//      注冊JDBC驅動
    try {
      Class.forName(JDBC_DRIVER);

//      數據庫的連接:通過DriverManager類的getConnection方法,傳入三個參數:數據庫URL、用戶名、用戶密碼,實例化connection對象
      connection = DriverManager.getConnection(JDBC_URL, USER, PASS);


    } catch (ClassNotFoundException e) {
      e.printStackTrace();
    } catch (SQLException e) {
      e.printStackTrace();
    }


  }



  public void add() {
    //      定義數據庫查詢語句:查詢aa表中的name、sex兩列數據
    String sql = "insert into taImage values(?,?,?) ";
//    讀取圖片,圖片放在電腦本地,所以我這里手動復制了路徑
    File file = new File("/Users/liuliu/Desktop/vv.jpeg");


    try {
      FileInputStream fi = new FileInputStream(file);
      preparedStatement = connection.prepareStatement(sql);
      preparedStatement.setInt(1, 2);
      preparedStatement.setString(2, "圖片一");
      preparedStatement.setBlob(3, fi);

//      執行查詢語句
      int f = preparedStatement.executeUpdate();

      if (f > 0) {
        System.out.println("插入成功");
      } else {
        System.out.println("插入失敗");
      }

      preparedStatement.close();
      connection.close();

    } catch (SQLException e) {
      e.printStackTrace();
    } catch (FileNotFoundException e) {
      e.printStackTrace();
    }


  }

  public void select() {

    Blob get_image;

    String sql = "select* from taImage";
    try {
//      將讀取到的圖片存放到指定的路徑中
      FileOutputStream fileOutputStream = new FileOutputStream("/Users/liuliu/Desktop/bb.jpg");

      preparedStatement = connection.prepareStatement(sql);

      ResultSet resultSet = preparedStatement.executeQuery();

      while (resultSet.next()) {

        get_image = resultSet.getBlob("photo");
//        將讀取到的Blob對象轉成字節流
        inputStream = get_image.getBinaryStream();
        int a;
        byte b[] = new byte[1014];
        while ((a = inputStream.read(b)) != -1) {
          fileOutputStream.write(b, 0, a);
        }


      }


    } catch (SQLException e) {
      e.printStackTrace();
    } catch (FileNotFoundException e) {
      e.printStackTrace();
    } catch (IOException e) {
      e.printStackTrace();
    }


  }


}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

兴和县| 新巴尔虎右旗| 奉节县| 巨野县| 镇宁| 田东县| 从化市| 鹤岗市| 金门县| 科技| 本溪| 汨罗市| 朝阳县| 喜德县| 寿阳县| 郑州市| 合阳县| 康保县| 靖江市| 阿图什市| 苍山县| 博爱县| 丰都县| 玉门市| 汾西县| 临沭县| 汶上县| 孝义市| 阿瓦提县| 花莲市| 定日县| 浠水县| 桦南县| 清河县| 嘉黎县| 南阳市| 辽阳县| 富宁县| 福建省| 勐海县| 松原市|