- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 MySQL 数据库,其中包含我从 MS Access 数据库导入的所有电影的列表。一个字段包含电影类型的可能值,电影可以有多种类型,所以我需要一种支持此功能的数据类型。在访问中,我可以将一个表“流派”链接到我的表“电影”中的字段“流派”,因此我可以选择无,每部电影一种或多种流派。当我切换到 MySQL 时,我使用 SET 数据类型来定义所有可能的值。到目前为止,一切都运行完美。我现在正尝试在 html/php 中设置一个表来显示 mysql 表。我希望表格能够排序:标题、流派、质量、评级等。但是对于流派排序,我需要来自集合数据类型的可能值。我不知道是否可以使用一些 php 命令/代码获取值,但是在我在网上潜伏了一段时间之后,我没有看到很多应用程序出于明显的负面原因使用 SET 数据类型.
所以我开始研究外键的可能性。我在这里遇到的问题是 - 据我所知 - 键只能包含一个可能的值,这让我回到了问题的开始。我确实喜欢外键的想法,因为它可以让我更轻松地向列表中添加新类型。
有没有可能我忽略了?是否可以从 SET 类型获取值到 php 或使用具有多种可能性的外键用于一条记录?
我知道我也可以手动将每个类型放入我的 php 脚本中,但我想将它们全部放在一个地方。这样一来,如果我添加一部电影的类型我还没有定义,我可以只在一个地方更新它,其他一切都会适应它。
最佳答案
Dagon 绝对正确 - 您的后端表格结构存在问题。您希望为多对多关系建模,而此时您当前的后端所能做的最好的事情就是建立一对多关系。
回顾:你有可以有多种类型的个人电影而且你有与许多电影相关的个人类型
关系数据库实际上不使用一种关系对多对多关系进行建模,它们使用一对多关系的递归并创建两个连接。
要为多对多关系建模,您需要三个表一张电影 table (我想你已经有了)流派表(我想你已经有了)正如 Dagon 所建议的那样,联结表将由电影 ID 和流派 ID 两个字段组成。
然后您设置两个单独的一对多关系。一个从电影表到联结表,一个从类型表到联结表。
现在,如果您想了解一部电影的所有流派,您只需过滤相关电影 ID 的联结表,如果您想了解特定类型的所有电影,您可以根据流派 ID 过滤联结表。
设置查找以将您的流派 ID 与文本描述相关联,然后您可以随意更改文本描述,如果您做对了,这将是一件很棒的事情,它将升级您表单中的每个值。
这是 SQL 设计和关系数据库设计背后的集合代数的绝对基础概念。
关于php - 外键与 SET 数据类型 MySQL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26287920/
初学者 android 问题。好的,我已经成功写入文件。例如。 //获取文件名 String filename = getResources().getString(R.string.filename
我已经将相同的图像保存到/data/data/mypackage/img/中,现在我想显示这个全屏,我曾尝试使用 ACTION_VIEW 来显示 android 标准程序,但它不是从/data/dat
我正在使用Xcode 9,Swift 4。 我正在尝试使用以下代码从URL在ImageView中显示图像: func getImageFromUrl(sourceUrl: String) -> UII
我的 Ubuntu 安装 genymotion 有问题。主要是我无法调试我的数据库,因为通过 eclipse 中的 DBMS 和 shell 中的 adb 我无法查看/data/文件夹的内容。没有显示
我正在尝试用 PHP 发布一些 JSON 数据。但是出了点问题。 这是我的 html -- {% for x in sets %}
我观察到两种方法的结果不同。为什么是这样?我知道 lm 上发生了什么,但无法弄清楚 tslm 上发生了什么。 > library(forecast) > set.seed(2) > tts lm(t
我不确定为什么会这样!我有一个由 spring data elasticsearch 和 spring data jpa 使用的类,但是当我尝试运行我的应用程序时出现错误。 Error creatin
在 this vega 图表,如果我下载并转换 flare-dependencies.json使用以下 jq 到 csv命令, jq -r '(map(keys) | add | unique) as
我正在提交一个项目,我必须在其中创建一个带有表的 mysql 数据库。一切都在我这边进行,所以我只想检查如何将我所有的压缩文件发送给使用不同计算机的人。基本上,我如何为另一台计算机创建我的数据库文件,
我有一个应用程序可以将文本文件写入内部存储。我想仔细看看我的电脑。 我运行了 Toast.makeText 来显示路径,它说:/数据/数据/我的包 但是当我转到 Android Studio 的 An
我喜欢使用 Genymotion 模拟器以如此出色的速度加载 Android。它有非常好的速度,但仍然有一些不稳定的性能。 如何从 Eclipse 中的文件资源管理器访问 Genymotion 模拟器
我需要更改 Silverlight 中文本框的格式。数据通过 MVVM 绑定(bind)。 例如,有一个 int 属性,我将 1 添加到 setter 中的值并调用 OnPropertyChanged
我想向 Youtube Data API 提出请求,但我不需要访问任何用户信息。我只想浏览公共(public)视频并根据搜索词显示视频。 我可以在未经授权的情况下这样做吗? 最佳答案 YouTube
我已经设置了一个 Twilio 应用程序,我想向人们发送更新,但我不想回复单个文本。我只是想让他们在有问题时打电话。我一切正常,但我想在发送文本时显示传入文本,以确保我不会错过任何问题。我正在使用 p
我有一个带有表单的网站(目前它是纯 HTML,但我们正在切换到 JQuery)。流程是这样的: 接受用户的输入 --- 5 个整数 通过 REST 调用网络服务 在服务器端运行一些计算...并生成一个
假设我们有一个名为 configuration.js 的文件,当我们查看内部时,我们会看到: 'use strict'; var profile = { "project": "%Projec
这部分是对 Previous Question 的扩展我的: 我现在可以从我的 CI Controller 成功返回 JSON 数据,它返回: {"results":[{"id":"1","Sourc
有什么有效的方法可以删除 ios 中 CBL 的所有文档存储?我对此有疑问,或者,如果有人知道如何从本质上使该应用程序像刚刚安装一样,那也会非常有帮助。我们正在努力确保我们的注销实际上将应用程序设置为
我有一个 Rails 应用程序,它与其他 Rails 应用程序通信以进行数据插入。我使用 jQuery $.post 方法进行数据插入。对于插入,我的其他 Rails 应用程序显示 200 OK。但在
我正在为服务于发布请求的 API 调用运行单元测试。我正在传递请求正文,并且必须将响应作为帐户数据返回。但我只收到断言错误 注意:数据是从 Azure 中获取的 spec.js const accou
我是一名优秀的程序员,十分优秀!