Maison  >  Article  >  base de données  >  Comment concevoir une structure de table MySQL fiable pour implémenter la fonction de stockage de fichiers ?

Comment concevoir une structure de table MySQL fiable pour implémenter la fonction de stockage de fichiers ?

王林
王林original
2023-10-31 09:57:111410parcourir

Comment concevoir une structure de table MySQL fiable pour implémenter la fonction de stockage de fichiers ?

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 :

  1. Méthodes de stockage de fichiers
    Le stockage de fichiers peut être utilisé de deux manières : stocker le fichier directement dans la base de données, ou stocker le fichier sur le disque et le chemin pour stocker le fichier dans la base de données. Le stockage des fichiers directement dans la base de données simplifie la gestion, mais peut affecter les performances de la base de données pour les fichiers volumineux. Par conséquent, lors de la conception d'une structure de table MySQL fiable, nous vous recommandons de stocker le fichier sur le disque et de stocker le chemin d'accès au fichier dans la base de données.
  2. Conception de la structure de la table
    Créez une table de fichiers dans la base de données pour gérer les informations relatives aux fichiers. La structure de la table de fichiers peut inclure les champs 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

  1. 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;
🎜🎜Conception d'interface d'opération de fichier🎜Afin de mettre en œuvre des opérations telles que le téléchargement, le téléchargement et la suppression de fichiers, nous pouvons concevoir des interfaces d'opération correspondantes pour la table des fichiers. Ce qui suit est un exemple de code PHP simple : 🎜🎜
<?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;
}

?>
🎜Dans les applications réelles, nous pouvons créer des extensions et des optimisations appropriées en fonction des besoins, telles que l'ajout de la gestion des autorisations de fichiers, de l'aperçu des fichiers et d'autres fonctions. 🎜🎜Pour résumer, concevoir une structure de table MySQL fiable pour implémenter la fonction de stockage de fichiers nécessite de prendre en compte la méthode de stockage de fichiers, la conception de la structure de table et la conception de l'interface d'opération de fichier. Grâce à une conception et une gestion raisonnables, nous pouvons réaliser des fonctions de stockage de fichiers efficaces et stables. 🎜

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn