首頁  >  文章  >  資料庫  >  如何使用 JDBC 將映像插入資料庫?

如何使用 JDBC 將映像插入資料庫?

WBOY
WBOY轉載
2023-08-29 14:05:02799瀏覽

如何使用 JDBC 将图像插入数据库?

PreparedStatement介面的setBinaryStream()方法接受一個表示參數索引的整數和一個InputStream對象,並將參數設為給定的InputStream物件。每當您需要發送非常大的二進位值時,您都可以使用此方法。

SQL 資料庫提供了一種名為 Blob(二進位大型物件)的資料類型,您可以在其中儲存大型二進位數據,例如映像。

使用JDBC 儲存映像

如果您需要使用JDBC 程式將映像儲存在資料庫中,請建立一個Blob 資料類型的表,如下所示:

CREATE TABLE Tutorial(Name VARCHAR(255), Type INT NOT NULL, Logo BLOB);

現在,使用JDBC 連接到資料庫並準備一個PreparedStatement 將值插入到上面建立的表中:

String query = "INSERT INTO Tutorial(Name, Type, Logo) VALUES (?, ?, ?)";
PreparedStatement pstmt = con.prepareStatement(query);

使用PreparedStatement介面的setter方法設定佔位符的值,並使用setBinaryStream( )方法設定Blob資料型別的值。

FileInputStream fin = new FileInputStream("javafx_logo.jpg");
pstmt.setBinaryStream(3, fin);

範例

以下範例示範如何使用 JDBC 程式將映像插入 MySQL 資料庫。在這裡,我們建立一個包含 Blob 資料類型的表,將值插入表中(Blob 類型的 BinaryStream 物件),並檢索表的內容。

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class InsertingImageToDatabase {
   public static void main(String args[]) throws Exception {
      //Registering the Driver
      DriverManager.registerDriver(new com.mysql.jdbc.Driver());
      //Getting the connection
      String mysqlUrl = "jdbc:mysql://localhost/sampleDB";
      Connection con = DriverManager.getConnection(mysqlUrl, "root", "password");
      System.out.println("Connection established......");
      //Creating the Statement
      Statement stmt = con.createStatement();
      //Executing the statement
      String createTable = "CREATE TABLE Tutorial( "
         + "Name VARCHAR(255), "
         + "Type VARCHAR(50), "
         + "Logo BLOB)";
      stmt.execute(createTable);
      //Inserting values
      String query = "INSERT INTO Tutorial(Name, Type, Logo) VALUES (?, ?, ?)";
      PreparedStatement pstmt = con.prepareStatement(query);
      pstmt.setString(1, "JavaFX");
      pstmt.setString(2, "Java_library");
      FileInputStream fin = new FileInputStream("E:\images\javafx_logo.jpg");
      pstmt.setBinaryStream(3, fin);
      pstmt.execute();

      pstmt.setString(1, "CoffeeScript");
      pstmt.setString(2, "scripting Language");
      fin = new FileInputStream("E:\images\coffeescript_logo.jpg");
      pstmt.setBinaryStream(3, fin);
      pstmt.execute();
      pstmt.setString(1, "Cassandra");
      pstmt.setString(2, "NoSQL database");
      fin = new FileInputStream("E:\images\cassandra_logo.jpg");
      pstmt.setBinaryStream(3, fin);
      pstmt.execute();
      System.out.println("Data inserted");
      ResultSet rs = stmt.executeQuery("Select *from Tutorial");
      while(rs.next()) {
         System.out.print("Name: "+rs.getString("Name")+", ");
         System.out.print("Tutorial Type: "+rs.getString("Type")+", ");
         System.out.print("Logo: "+rs.getBlob("Logo"));
         System.out.println();
      }
   }
}

輸出

Connection established......
Data inserted
Name: JavaFX, Tutorial Type: Java_library, Logo: com.mysql.jdbc.Blob@7dc5e7b4
Name: CoffeeScript, Tutorial Type: scripting Language, Logo:
com.mysql.jdbc.Blob@1ee0005
Name: Cassandra, Tutorial Type: NoSQL database, Logo: com.mysql.jdbc.Blob@75a1cd57

注意:您只能使用 JDBC 程式儲存和檢索 .gif 或 .jpeg 或 .png 類型的映像。

以上是如何使用 JDBC 將映像插入資料庫?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:tutorialspoint.com。如有侵權,請聯絡admin@php.cn刪除