目次
Blob をデータベースに保存する
データベースから BLOB を取得する
ホームページ データベース mysql チュートリアル JDBC Blob データ型とは何ですか?データを保存したり読み取ったりするにはどうすればよいですか?

JDBC Blob データ型とは何ですか?データを保存したり読み取ったりするにはどうすればよいですか?

Sep 14, 2023 pm 06:57 PM

什么是 JDBC Blob 数据类型?如何存储和读取其中的数据?

BLOB は、最大長 65535 文字の可変量のデータを保持できるバイナリ ラージ オブジェクトです。

画像やその他の種類のデータなど、大量のバイナリ データを保存するために使用されます。書類。 TEXT として定義されたフィールドにも大量のデータが保持されます。 2 つの違いは、格納されたデータの並べ替えと比較では、BLOB では大文字と小文字が区別されますが、TEXT フィールドでは大文字と小文字が区別されないことです。 BLOB または TEXT を使用して長さを指定しませんでした。

Blob をデータベースに保存する

Blob データ型をデータベースに保存するには、JDBC プログラムを使用して次の手順に従います

ステップ 1: データベースに接続する

MySQL URL (jdbc:mysql:) を渡すことで、DriverManagergetConnection()

メソッド

を使用してデータベースに接続できます。 //localhost /sampleDB) (exampleDB はデータベース名)、ユーザー名とパスワードを getConnection() メソッドのパラメーターとして使用します。

String mysqlUrl = "jdbc:mysql://localhost/sampleDB";
Connection con = DriverManager.getConnection(mysqlUrl, "root", "password");
ログイン後にコピー

ステップ 2: プリペアド ステートメントを作成する

Connection インターフェイスの prepareStatement() メソッドを使用して、プリペアド ステートメントを作成します。 PreparedStatement オブジェクト。挿入クエリ (プレースホルダー付き) をパラメーターとしてこのメ​​ソッドに渡します。

PreparedStatement pstmt = con.prepareStatement("INSERT INTO MyTableVALUES(?, ?)");
ログイン後にコピー

ステップ 3: プレースホルダーの値を設定する

PreparedStatement インターフェイスの setter メソッドを使用して、プレースホルダーに値を設定します。列のデータ型に基づいてメソッドを選択します。たとえば、列の型が VARCHAR の場合は setString() メソッドを使用し、列の型が INT の場合は setInt() メソッドを使用できます。

列の型が Blob の場合は、setBinaryStream() メソッドまたは setBlob() メソッドを使用して値を設定できます。これらのメソッドには、パラメーター インデックスを表す整数変数と、InputStream クラスのオブジェクトがパラメーターとして渡されます。

pstmt.setString(1, "sample image");
//Inserting Blob type
InputStream in = new FileInputStream("E:\images\cat.jpg");
pstmt.setBlob(2, in);
ログイン後にコピー

ステップ 4: ステートメントを実行します。

PreparedStatement インターフェイスの execute() メソッドを使用して、オブジェクトの上に作成された PreparedStatement。

データベースから BLOB を取得する

ResultSet インターフェイスの getBlob() メソッドは、列のインデックスを表す整数 (または列名を表す文字列値) を受け入れ、その値を取得します。指定された列の値が返され、Blob オブジェクトとして返されます。

while(rs.next()) {
   rs.getString("Name");
   rs.getString("Type");
   Blob blob = rs.getBlob("Logo");
}
ログイン後にコピー

Blob インターフェイスの getBytes() メソッドは、現在の Blob オブジェクトの内容を取得し、バイト配列として返します。

getBlob() メソッドを使用すると、BLOB の内容をバイト配列に取得し、write() メソッドを使用してイメージを作成できます。 FileOutputStream オブジェクト。

byte byteArray[] = blob.getBytes(1,(int)blob.length());
FileOutputStream outPutStream = new FileOutputStream("path");
outPutStream.write(byteArray);
ログイン後にコピー

次の例では、MySQL データベースに BLOB データ型のテーブルを作成し、そこにイメージを挿入します。それを取得してローカル ファイル システムに保存します。

import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.sql.Blob;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.Statement;
public class BlobExample {
   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 a table
      Statement stmt = con.createStatement();
      stmt.execute("CREATE TABLE SampleTable( Name VARCHAR(255), Image BLOB)");
      System.out.println("Table Created");
      //Inserting values
      String query = "INSERT INTO SampleTable(Name,image) VALUES (?, ?)";
      PreparedStatement pstmt = con.prepareStatement(query);
      pstmt.setString(1, "sample image");
      FileInputStream fin = new FileInputStream("E:\images\cat.jpg");
      pstmt.setBlob(2, fin);
      pstmt.execute();
      //Retrieving the data
      ResultSet rs = stmt.executeQuery("select * from SampleTable");
      int i = 1;
      System.out.println("Contents of the table are: ");
      while(rs.next()) {
         System.out.println(rs.getString("Name"));
         Blob blob = rs.getBlob("Image");
         byte byteArray[] = blob.getBytes(1,(int)blob.length());
         FileOutputStream outPutStream = new
         FileOutputStream("E:\images\blob_output"+i+".jpg");
         outPutStream.write(byteArray);
         System.out.println("E:\images\blob_output"+i+".jpg");
         System.out.println();
         i++;
      }
   }
}
ログイン後にコピー

出力

Connection established......
Table Created
Contents of the table are:
sample image
E:\images\blob_output1.jpg
ログイン後にコピー

以上がJDBC Blob データ型とは何ですか?データを保存したり読み取ったりするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか? Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか? Mar 19, 2025 pm 03:51 PM

この記事では、MySQLのAlter Tableステートメントを使用して、列の追加/ドロップ、テーブル/列の名前の変更、列データ型の変更など、テーブルを変更することについて説明します。

INNODBフルテキスト検索機能を説明します。 INNODBフルテキスト検索機能を説明します。 Apr 02, 2025 pm 06:09 PM

INNODBのフルテキスト検索機能は非常に強力であり、データベースクエリの効率と大量のテキストデータを処理する能力を大幅に改善できます。 1)INNODBは、倒立インデックスを介してフルテキスト検索を実装し、基本的および高度な検索クエリをサポートします。 2)一致を使用してキーワードを使用して、ブールモードとフレーズ検索を検索、サポートします。 3)最適化方法には、単語セグメンテーションテクノロジーの使用、インデックスの定期的な再構築、およびパフォーマンスと精度を改善するためのキャッシュサイズの調整が含まれます。

MySQL接続用のSSL/TLS暗号化を構成するにはどうすればよいですか? MySQL接続用のSSL/TLS暗号化を構成するにはどうすればよいですか? Mar 18, 2025 pm 12:01 PM

記事では、証明書の生成と検証を含むMySQL用のSSL/TLS暗号化の構成について説明します。主な問題は、セルフ署名証明書のセキュリティへの影響を使用することです。[文字カウント:159]

人気のあるMySQL GUIツール(MySQL Workbench、PhpMyAdminなど)は何ですか? 人気のあるMySQL GUIツール(MySQL Workbench、PhpMyAdminなど)は何ですか? Mar 21, 2025 pm 06:28 PM

記事では、MySQLワークベンチやPHPMyAdminなどの人気のあるMySQL GUIツールについて説明し、初心者と上級ユーザーの機能と適合性を比較します。[159文字]

MySQLの大きなデータセットをどのように処理しますか? MySQLの大きなデータセットをどのように処理しますか? Mar 21, 2025 pm 12:15 PM

記事では、MySQLで大規模なデータセットを処理するための戦略について説明します。これには、パーティション化、シャード、インデックス作成、クエリ最適化などがあります。

ドロップテーブルステートメントを使用してMySQLにテーブルをドロップするにはどうすればよいですか? ドロップテーブルステートメントを使用してMySQLにテーブルをドロップするにはどうすればよいですか? Mar 19, 2025 pm 03:52 PM

この記事では、ドロップテーブルステートメントを使用してMySQLのドロップテーブルについて説明し、予防策とリスクを強調しています。これは、バックアップなしでアクションが不可逆的であることを強調し、回復方法と潜在的な生産環境の危険を詳述しています。

さまざまなタイプのMySQLインデックス(Bツリー、ハッシュ、フルテキスト、空間)を説明します。 さまざまなタイプのMySQLインデックス(Bツリー、ハッシュ、フルテキスト、空間)を説明します。 Apr 02, 2025 pm 07:05 PM

MySQLは、Bツリー、ハッシュ、フルテキスト、および空間の4つのインデックスタイプをサポートしています。 1.B-Treeインデックスは、等しい値検索、範囲クエリ、ソートに適しています。 2。ハッシュインデックスは、等しい値検索に適していますが、範囲のクエリとソートをサポートしていません。 3.フルテキストインデックスは、フルテキスト検索に使用され、大量のテキストデータの処理に適しています。 4.空間インデックスは、地理空間データクエリに使用され、GISアプリケーションに適しています。

JSON列にインデックスを作成するにはどうすればよいですか? JSON列にインデックスを作成するにはどうすればよいですか? Mar 21, 2025 pm 12:13 PM

この記事では、クエリパフォーマンスを強化するために、PostgreSQL、MySQL、MongoDBなどのさまざまなデータベースでJSON列にインデックスの作成について説明します。特定のJSONパスのインデックス作成の構文と利点を説明し、サポートされているデータベースシステムをリストします。

See all articles