画像ファイルや 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_packet=24M
5. それでもエラーが発生する場合:
遅い接続で大きなファイルを保存した場合、PHP のデフォルトの時間制限は 30 秒です。 max_execution_time (php.ini 内) の値を -1 に変更できます
異なるデータベースのテーブルを削除する SQL ステートメントの作成方法の詳細な説明
3. 1 台のマシンで複数の MySQL サービスを実行する方法を説明します4. 仮想ホストを使用しない小規模な MySQL データベース バックアップ スクリプト
5. mysqldump を使用してテーブルをバックアップおよび復元する詳細な例
以上がphpでmysqlに画像を保存する例を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

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

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

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

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

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

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

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


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

メモ帳++7.3.1
使いやすく無料のコードエディター

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

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

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

ホットトピック









