gpt4 book ai didi

php - 使用 find_in_set 从 1 行中选择包含值的列

转载 作者:行者123 更新时间:2023-11-30 00:54:52 24 4
gpt4 key购买 nike

我有一个包含许多行和列的表格。我想找到包含某个值的列,但只搜索 1 行,当 ID=7 时。

下列表达式的正确写法是什么?

SELECT *   
FROM mytable
WHERE FIND_IN_SET(400, list_column)
WHEN ID=7;

谢谢。

最佳答案

您不能按照您建议的形式执行此操作。

在单个查询中显示包含 400 的列的最佳方法是使用 CASE 或类似的方法,测试中每列一个案例。例如:

SELECT CASE
WHEN col1=400 THEN 'col1'
WHEN col2=400 THEN 'col2'
WHEN col3=400 THEN 'col3'
...
ELSE 'Not found'
END CASE
FROM mytable
WHERE id=7

可以通过动态 SQL(或 PHP 等效项)使用 INFORMATION_SCHEMA 查询读取表中的所有列,并在第二个查询(例如上面的查询)中使用这些列来实现此目的。

但是,我猜测您想要执行此操作的原因是因为您的表不在 first normal form 中,并且您在列中存储重复值。您可能需要查找第一个范式,看看情况是否确实如此,以及是否应该重新设计数据库以避免此问题和其他问题。

关于php - 使用 find_in_set 从 1 行中选择包含值的列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20660337/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com