首页 > 解决方案 > 在php中使用数组和内爆函数的自定义查询

问题描述

我正在编写一个游戏网站。在这个网站上,每个问题都应该只向用户显示一次。问题 ID 存储在一个字段中:

表中的字段名称:hidden_​​questions

hidden_​​questions 值:1,2,3,17

我正在尝试从数据库中获取 ID 并使用 implode 函数将它们存储在数组中:

$q1= array($data['question_id']);
$q2= implode(',', $q1); // returns 1,2,3,4,5

我想使用以下查询显示一个非重复问题:

$sql = "SELECT * FROM question WHERE question_id!=('".$q2."') LIMIT 1";

此代码不起作用,并显示 ID 存储在hidden_​​questions字段中的问题。请指导我。

标签: phpmysqlimplode

解决方案


我看到有人已经写了关于解决方案的评论,但我仍然为你写下来。

你走对了,我明白你想做什么。!=但是,MySQL在这种语法中没有类似的东西。

也许你可以尝试使用NOT IN

$sql = "SELECT * FROM question WHERE question_id NOT IN (".$b.") LIMIT 1";

另外,你为什么使用LIMIT 1? 根据您的解释,您似乎想要显示多个问题。

免责声明:我没有测试代码,也许你需要玩一些引号。但这应该是解决方案


推荐阅读