Comment concevoir une structure de table MySQL fiable pour implémenter la fonction de stockage de fichiers ?
Actuellement, le stockage de fichiers fait désormais partie intégrante de nombreuses applications. Lors de la conception d'une structure de table MySQL fiable, nous devons prendre en compte les facteurs clés suivants :
id
: identifiant du fichier, comme clé primaire ; id
:文件ID,作为主键;name
:文件名;path
:文件路径;size
:文件大小;type
:文件类型;created_at
:文件创建时间;updated_at
name
: nom du fichier path code> : chemin du fichier ;
size
: taille du fichier type
: type de fichier created_at
: heure de création du fichier ;
updated_at
: heure de mise à jour du fichier. 🎜Par exemple, vous pouvez utiliser l'instruction SQL suivante pour créer une table de fichiers : 🎜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; } ?>
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!