検索
ホームページデータベースmysql チュートリアルphpでmysqlに画像を保存する例を詳しく解説

画像ファイルや HTML ファイルなどのバイナリ データを MySQL データベースに直接保存したい場合は、この記事が最適です。 HTML フォームを介してこれらのファイルを保存する方法と、これらのファイルにアクセスして使用する方法を説明します。
この記事の概要:
。 mysql で新しいデータベースを作成します
。ファイルを保存する方法のサンプルプログラム
。ファイルにアクセスする方法のサンプル プログラム
mysql で新しいデータベースを作成する
まず、mysql で新しいデータベースを作成する必要があります。このデータベースにバイナリ ファイルを保存します。この例では、次の構造を使用します。データベースを作成するには、
次の手順を実行する必要があります。 MySQL コントローラー
を入力します。 「データベース binary_data を作成する
」コマンドを入力します。 「use binary_data;」というコマンドを入力します。コマンド
「CREATE TABLE binary_data (id INT(4) NOT NULL AUTO_INCREMENT PRIMARY KEY,description CHAR(50), bin_data LONGBLOB, filename CHAR(50), filesize CHAR(50), filetype CHAR(50));」を入力します。改行不可)
事故がなければデータベースとテーブルを作成する必要があります。
ファイルを保存する方法のサンプルプログラム
このサンプルを使用すると、HTML フォームを通じてファイルをデータベースに転送できます。
store.php3
// store.php3 - Florian Dittmer
?>
// フォームが送信されると、コードが実行されます:
if ($submit) {
/ / データベースへの接続
// (ホスト名、ユーザー名、パスワードを調整する必要がある場合があります)
MYSQL_CONNECT( "localhost", "root", "password");
$data = addedlashes (fread(fopen ($form_data, "r"), filesize($form_data)));
$result=MYSQL_QUERY( "INSERT INTO binary_data (description,bin_data,filename,filesize,filetype)
[前の行からの続き: ] VALUES ($form_description, $data,$form_data_name,$form_data_size,$form_data_type)");
$id= mysql_insert_id();
print "
このファイルには次のデータベース ID があります: $id";
MYSQL_CLOSE();
} else {
/ / それ以外の場合は、新しいデータを保存するためのフォームを表示します
?>
ファイルの説明:

データベースにアップロード/保存するファイル:

}
?>
このプログラムを実行すると、単純な HTML フォームを参照し、「参照」をクリックしてファイルを選択し、「送信」をクリックします。
ファイルがウェブサーバーにアップロードされると、プログラムはアップロードしたばかりのファイルの ID を通知しますので、後で使用するためにこの ID を覚えておいてください。
ファイルにアクセスする方法に関するサンプル プログラム
このプログラムを通じて保存したファイルにアクセスできます
//getdata.php3 - Florian Dittmer 作成
//メソッドの呼び出し: getdata.php3?id =
if($id) {
// ホスト名、ユーザー名、パスワードを調整する必要がある場合があります:
@MYSQL_CONNECT( "localhost", "root", "password");
@mysql_select_db( "binary_data"); $query = "id=$id の bin_data,filetype を選択";
$result = @MYSQL_QUERY($query)
$data = @MYSQL_RESULT($result,0, "bin_data"); MYSQL_RESULT( $result,0, "filetype");
echo $data;
?> を使用する必要があります。 ID をパラメータとして指定します。
例: データベース内のファイルの ID は 2 です。次のように呼び出すことができます:
getdata.php3?id=2
画像をデータベースに保存すると、画像のように呼び出すことができます。
例: データベース内の画像ファイルの ID は 3 です。次のように呼び出すことができます:
1MB を超えるファイルを保存する方法:
1MB を超えるファイルを保存したい場合は、プログラム、PHP 設定を構成する必要があります、および SQL 設定に多くの変更が加えられました。
次の項目は、24MB 未満のファイルを保存するのに役立ちます:
1. store.php3 を変更し、MAX_FILE_SIZE の値を 24000000 に変更します。
2. PHP 設定を変更します。通常、PHP は 2MB 未満のファイルのみを許可します。(php.ini の) max_filesize の値を 24000000 に変更する必要があります (MYSQL の場合)。 1 MB パケット未満です。
4. 次のパラメータを使用して MYSQL を再起動する必要があります
/usr/local/bin/safe_mysqld -O key_buffer=16M -O table_cache=128 -O sort_buffer=4M -O Record_buffer= 1M -O max_allowed_pa​​cket=24M
5. それでもエラーが発生する場合:
遅い接続で大きなファイルを保存した場合、PHP のデフォルトの時間制限は 30 秒です。 max_execution_time (php.ini 内) の値を -1 に変更できます

【関連おすすめ】

Mysql 無料ビデオチュートリアル

2

異なるデータベースのテーブルを削除する SQL ステートメントの作成方法の詳細な説明

3. 1 台のマシンで複数の MySQL サービスを実行する方法を説明します

4. 仮想ホストを使用しない小規模な MySQL データベース バックアップ スクリプト

5. mysqldump を使用してテーブルをバックアップおよび復元する詳細な例

以上がphpでmysqlに画像を保存する例を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
MySQLと他のSQL方言の構文の違いは何ですか?MySQLと他のSQL方言の構文の違いは何ですか?Apr 27, 2025 am 12:26 AM

MySQLdiffersfromotherSQLdialectsinsyntaxforLIMIT,auto-increment,stringcomparison,subqueries,andperformanceanalysis.1)MySQLusesLIMIT,whileSQLServerusesTOPandOracleusesROWNUM.2)MySQL'sAUTO_INCREMENTcontrastswithPostgreSQL'sSERIALandOracle'ssequenceandt

MySQLパーティションは何ですか?MySQLパーティションは何ですか?Apr 27, 2025 am 12:23 AM

MySQLパーティション化により、パフォーマンスが向上し、メンテナンスが簡素化されます。 1)大きなテーブルを特定の基準(日付範囲など)、2)物理的に独立したファイルに物理的に分割する、3)MySQLはクエリするときに関連するパーティションに焦点を合わせることができます。

MySQLで特権をどのように許可して取り消しますか?MySQLで特権をどのように許可して取り消しますか?Apr 27, 2025 am 12:21 AM

mysqlで許可を許可および取り消す方法は? 1。grantallprivilegesondatabase_name.to'username'@'host 'などの許可を付与するために付与ステートメントを使用してください。 2。Revokeallprivilegesondatabase_name.from'username'@'host 'など、Revoke Statementを使用して、許可のタイムリーな通信を確保します。

InnoDBとMyisamストレージエンジンの違いを説明してください。InnoDBとMyisamストレージエンジンの違いを説明してください。Apr 27, 2025 am 12:20 AM

INNODBは、トランザクションサポートと高い並行性を必要とするアプリケーションに適していますが、Myisamはより多くの読み取りとより少ない書き込みを必要とするアプリケーションに適しています。 1.INNODBは、eコマースおよび銀行システムに適したトランザクションおよび銀行レベルのロックをサポートしています。 2. Myisamは、ブログやコンテンツ管理システムに適した、迅速な読み取りとインデックス作成を提供します。

MySQLの結合のさまざまなタイプは何ですか?MySQLの結合のさまざまなタイプは何ですか?Apr 27, 2025 am 12:13 AM

MySQLには4つのメイン結合タイプがあります:innerjoin、leftjoin、rightjoin、fullouterjoin。 1.InnerJoinは、結合条件を満たす2つのテーブルのすべての行を返します。 2.右のテーブルに一致する行がない場合でも、Leftjoinは左のテーブルのすべての行を返します。 3。右joinはleftjoinに反しており、右のテーブルのすべての行を返します。 4.fullouterjoinは、結合条件を満たしている、または満たさない2つのテーブルのすべての行を返します。

MySQLで利用可能なさまざまなストレージエンジンは何ですか?MySQLで利用可能なさまざまなストレージエンジンは何ですか?Apr 26, 2025 am 12:27 AM

mysqloffersvariousstorageEngines、それぞれのfordifferentusecases:1)Innodbisidealforapplicationsingingidcomplianceanceandhighconcurrency、support transactions andforeignkeys.2)myisamisbestforread-havyworkloads、transactionsupptort.3)

MySQLの一般的なセキュリティの脆弱性は何ですか?MySQLの一般的なセキュリティの脆弱性は何ですか?Apr 26, 2025 am 12:27 AM

MySQLの一般的なセキュリティの脆弱性には、SQLインジェクション、弱いパスワード、不適切な許可構成、および非合事ソフトウェアが含まれます。 1。SQL注射は、前処理ステートメントを使用することで防ぐことができます。 2。強力なパスワード戦略を強制的に使用することにより、弱いパスワードを回避できます。 3.不適切な許可構成は、ユーザー許可の定期的なレビューと調整を通じて解決できます。 4.未使用のソフトウェアは、MySQLバージョンを定期的にチェックして更新することでパッチを適用できます。

MySQLでスロークエリをどのように識別できますか?MySQLでスロークエリをどのように識別できますか?Apr 26, 2025 am 12:15 AM

MySQLの遅いクエリを識別することは、遅いクエリログを有効にし、しきい値を設定することで実現できます。 1.スロークエリログを有効にし、しきい値を設定します。 2.スロークエリログファイルを表示および分析し、詳細な分析のためにMySQLDumpSlowやPT-Query-Digestなどのツールを使用します。 3.インデックスの最適化、クエリの書き換え、およびselect*の使用を回避することで、遅いクエリの最適化を実現できます。

See all articles

ホット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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

メモ帳++7.3.1

メモ帳++7.3.1

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

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

SublimeText3 中国語版

SublimeText3 中国語版

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

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません