php - mysql 中逗号分隔字段的更好替代方案

标签 php mysql database

在我的应用程序中,每当用户上传壁纸时,我都需要将该壁纸裁剪成 3 种不同的尺寸并将所有这些路径(裁剪图像的 3 条路径和原始上传壁纸的 1 条路径)存储到我的数据库中。
我还需要存储原始壁纸的 tinyurl(用户上传的)。

在解决上述问题时,我提出了以下表结构。

CREATE TABLE `wallpapermaster` (
  `wallpaperid` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `userid` bigint(20) NOT NULL,
  `wallpaperloc` varchar(100) NOT NULL,
  `wallpapertitle` varchar(50) NOT NULL,
  `wallpaperstatus` tinyint(4) DEFAULT '0' COMMENT '0-Waiting,1-approved,2-disapproved',
  `tinyurl` varchar(40) NOT NULL
) ENGINE=MyISAM

wallpaperloc 是一个逗号分隔的字段,由原始壁纸位置加上所有裁剪实例的位置组成。

我知道使用逗号分隔的字段在关系数据库的世界中被认为是一种糟糕的设计,所以你想推荐一些其他简洁有效的方法吗?

最佳答案

在 wallpapermaster 和位置表之间使用 1:n 关系。

像这样:

CREATE TABLE wallpapermaster (
  wallpaperid     int unsigned NOT NULL AUTO_INCREMENT,
  userid          bigint NOT NULL,
  wallpaperloc    varchar(100) NOT NULL,
  wallpapertitle  varchar(50) NOT NULL,
  wallpaperstatus tinyint DEFAULT '0' COMMENT '0-Waiting,1-approved,2-disapproved',
  primary key (wallpaperid)
) ENGINE=InnoDB;


CREATE TABLE wallpaperlocation (
  wallpaperid  int unsigned NOT NULL,
  location     varchar(100) NOT NULL,
  tinyurl      varchar(40),
  constraint fk_loc_wp 
      foreign key (wallpaperid) 
      references wallpapermaster (wallpaperid),
   primary key (wallpaperid, location)
) ENGINE=InnoDB;

wallpaperlocation 中的主键确保同一位置不能插入两次。

请注意,int(10) 没有定义任何数据类型约束。这只是客户端应用程序的一个提示,以指示该号码有多少位数。

关于php - mysql 中逗号分隔字段的更好替代方案,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14275992/

相关文章:

mysql - 如何获取mysql中未映射的记录

sql - 使用模型关联查找

java - 强制方法调用以避免抛出异常

php - 当 PHP Fatal error 发生时,Nginx 向浏览器报告 HTTP Error 500

php - Doctrine 查询构建器中的嵌套查询

php - 为什么 jQuery 单击事件监听器未在 WooCommerce 按钮上注册?

php - 如何对mysql中的枚举字段进行排序

MySQL 错误 - "check syntax to use near ' %s”

php - 从数据库格式化日期

javascript - 循环更改多个 anchor 的 href 内容