ホームページ >データベース >mysql チュートリアル >MySQL は画像テーブルを作成して画像のアップロードと管理機能を実装します
MySQL は、画像のアップロードおよび管理機能を実装するために画像テーブルを作成します
多くの Web アプリケーションでは、画像のアップロードおよび管理機能は非常に一般的な要件の 1 つです。 MySQL データベースは、画像を含むさまざまな種類のデータの保存と管理に使用できる、一般的に使用されるリレーショナル データベースです。
この記事では、MySQL を使用して画像テーブルを作成し、このテーブルを使用して画像のアップロードおよび管理機能を実装する方法を紹介します。同時に、読者がよりよく理解して実践できるように、いくつかのサンプルコードも提供されます。
まず、MySQL データベースにログインし、images
という名前のデータベースを作成します。次に、次の列を含む images
という名前のテーブルを作成します。
id
: 自動インクリメントする整数型を使用した、画像の一意の識別子。 name
: 文字列タイプを使用したイメージの名前。 file
: 文字列タイプを使用した画像のファイル名。 size
: 整数型を使用した画像のファイル サイズ。 type
: 文字列タイプを使用した画像のファイルタイプ。 created_at
: 日付と時刻のタイプを使用したイメージの作成時刻。 テーブルを作成するための具体的な SQL ステートメントは次のとおりです:
CREATE TABLE `images` ( `id` INT AUTO_INCREMENT PRIMARY KEY, `name` VARCHAR(100) NOT NULL, `file` VARCHAR(100) NOT NULL, `size` INT NOT NULL, `type` VARCHAR(100) NOT NULL, `created_at` DATETIME DEFAULT CURRENT_TIMESTAMP );
次に、画像用の PHP を記述します。アップロード ユーザーがアップロードした画像をサーバーに保存し、関連情報をデータベースに挿入するために使用されるスクリプト。
まず、ユーザーが選択した画像ファイルを受け入れるための HTML フォームを作成します。
<form action="upload.php" method="post" enctype="multipart/form-data"> <input type="file" name="image" /> <input type="submit" value="Upload" /> </form>
次に、画像アップロードのロジックを処理する upload.php
スクリプトを作成します。 :
<?php // 检查是否有文件上传 if(isset($_FILES['image'])) { // 获取上传的文件信息 $file = $_FILES['image']; $name = $file['name']; $tmp_name = $file['tmp_name']; $size = $file['size']; $type = $file['type']; // 将文件保存到服务器的指定目录 $upload_path = 'uploads/'; $new_name = uniqid() . '_' . $name; $destination = $upload_path . $new_name; move_uploaded_file($tmp_name, $destination); // 将文件信息插入到数据库 $db = new mysqli('localhost', 'root', 'password', 'images'); $sql = "INSERT INTO images (name, file, size, type) VALUES ('$name', '$new_name', $size, '$type')"; $db->query($sql); $db->close(); echo 'File uploaded successfully!'; } ?>
上記のコードは、ユーザーがアップロードした画像を uploads/
ディレクトリに保存し、同時に画像の関連情報を images# に挿入します。 ## データベースのテーブル。
images.php:
<?php $db = new mysqli('localhost', 'root', 'password', 'images'); $sql = "SELECT * FROM images"; $result = $db->query($sql); while($row = $result->fetch_assoc()) { echo '<img src="uploads/' . $row['file'] . '" alt="' . $row['name'] . '" />'; } $db->close(); ?>上記のコードは、アップロードされた各画像を順番に出力します ## Web ページ上のすべての画像を表示するには、画像の #a1f02c36ba31691bcfe87b2722de723b
タグを使用します。 画像を削除する機能については、実際のニーズに応じて対応するロジックを設計し、対応する PHP スクリプトを作成して実装できます。
概要
この記事では、MySQL を使用して画像テーブルを作成し、このテーブルを使用して画像のアップロードおよび管理機能を実装する方法を紹介します。同時に、読者がよりよく理解して実践できるように、いくつかのサンプル コードが提供されています。
画像関連情報をデータベースに保存することで、ファイルシステムに限らず画像データをより便利に管理・運用することができます。もちろん、特定のアプリケーションのシナリオや要件は異なる場合があり、読者は実際の状況に応じて柔軟に調整および拡張できます。
以上がMySQL は画像テーブルを作成して画像のアップロードと管理機能を実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。