我完全意识到在表列中使用分隔列表而不是将数据规范化到多个表中是多么糟糕。
虽然,我确实有一个多年前设计的表格结构,我很快就会重新设计。
简化后,它看起来像这样:
Table: Newsletters
+------------+---------------+
| subject | mailing_lists |
+------------+---------------+
| A Test | 1,2 |
| More Tests | 2,3 |
+------------+---------------+
如果您愿意,可以在这个SQLFiddle中看到它。
最近,我为我的用户提供了编写邮件列表 ID 的分隔列表 (如 1,3)的选项,作为选择在视图中显示哪些新闻通讯的功能。
(例如,仅显示发送到 ID 为 1 或 3 的列表的新闻通讯)
所以:一个带有分隔的 id 列表的表列,并将分隔的 id 作为输入。
如果表格被规范化,这显然会容易得多。
所以,我在 PHP 中解决了这个问题,通过分解输入 id 并迭代它们来创建一个查询,就像上面提到的小提琴中的查询一样,它看起来像这样:
SELECT * FROM `newsletters`
WHERE FIND_IN_SET("1", `mailing_lists`) > 0
OR FIND_IN_SET("3", `mailing_lists`) > 0
这个查询完美地获取了我想要获取的数据,但我只能以编程方式创建它,因为我必须为分隔列表中的每个 id 添加一个新条件。
问题是:纯粹出于好奇:有没有办法避免 PHP 中的循环,并在不拆分代码中的 id 的情况下进行查询?