Wie entwerfe ich eine zuverlässige MySQL-Tabellenstruktur zur Implementierung der Dateispeicherfunktion?
Aktuell ist die Dateispeicherung ein fester Bestandteil vieler Anwendungen. Beim Entwerfen einer zuverlässigen MySQL-Tabellenstruktur müssen wir die folgenden Schlüsselfaktoren berücksichtigen:
id
: Datei-ID, als Primärschlüssel; id
:文件ID,作为主键;name
:文件名;path
:文件路径;size
:文件大小;type
:文件类型;created_at
:文件创建时间;updated_at
name
: Dateiname; code>path code>: Dateipfad; size
: Dateigröße;
type
: Dateityp; created_at
: Dateierstellungszeit; updated_at
: Dateiaktualisierungszeit.
Zum Beispiel können Sie die folgende SQL-Anweisung verwenden, um eine Dateitabelle zu erstellen:
CREATE TABLE `file` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) NOT NULL, `path` varchar(255) NOT NULL, `size` int(11) NOT NULL, `type` varchar(255) NOT NULL, `created_at` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, `updated_at` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
<?php function uploadFile($file) { $name = $file['name']; $path = 'uploads/' . $name; $size = $file['size']; $type = $file['type']; move_uploaded_file($file['tmp_name'], $path); $sql = "INSERT INTO `file` (`name`, `path`, `size`, `type`) VALUES ('$name', '$path', $size, '$type')"; // 执行SQL语句插入文件信息 return true; } function downloadFile($id) { $sql = "SELECT `path` FROM `file` WHERE `id` = $id"; // 执行SQL语句查询文件路径 $path = $result['path']; header('Content-Type: application/octet-stream'); header("Content-Disposition: attachment; filename="" . basename($path) . """); readfile($path); return true; } function deleteFile($id) { $sql = "SELECT `path` FROM `file` WHERE `id` = $id"; // 执行SQL语句查询文件路径 $path = $result['path']; unlink($path); $sql = "DELETE FROM `file` WHERE `id` = $id"; // 执行SQL语句删除文件信息 return true; } ?>
Das obige ist der detaillierte Inhalt vonWie entwerfe ich eine zuverlässige MySQL-Tabellenstruktur zur Implementierung der Dateispeicherfunktion?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!