1

所以我在一张表中有一个 CSV 列表。(例如:) 1,3,19我想从另一个表中搜索所有用户名,其中 id 与其中任何一个匹配。

我觉得我应该能够做类似的事情:

<?
$query = "SELECT player_ids FROM cast_list WHERE game='".$gameid."' ";
$result = mysql_query($query) or die(mysql_error());
$playerquery = "SELECT username,id FROM players WHERE id IN (".$result.") ORDER BY username;
$player_result = mysql_query($playerquery) or die(mysql_error());
echo "<ul>";
while ($row = mysql_fetch_array($player_result) ) {
  echo "<li>".$row['username']."</li>";
}
echo "</ul>";
?>

但我无法让它工作。我究竟做错了什么?

4

2 回答 2

1

您还可以使用子查询(这会更快):

$playerquery = "SELECT username,id 
                FROM players 
                WHERE id IN (SELECT player_ids FROM cast_list WHERE game='".$gameid."') 
                ORDER BY username";

顺便说一句,如果game是一个整数字段,您没有' '在值周围加上引号 ()。

于 2010-02-02T08:14:05.973 回答
0

这个想法是正确的,但是您需要将 转移$result到实际的字符串数组:

$game_ids = array();
while ($row = mysql_fetch_array($result) ) {
 $game_ids[] = .$row[1];
}

现在使用implode逗号将数组转换为逗号分隔值:

$playerquery = "SELECT username,id FROM players WHERE id IN (" . implode(",",$result) . ") ORDER BY username;
于 2010-02-02T06:24:01.280 回答