选择包含2个可能值的MYSQL记录


SELECT MYSQL record containing 2 possible values

我想选择返回值的行。如果他们在选择框中选择了MaleFemale,我希望它搜索它。那部分工作正常。然而,如果他们选择Either,我想说MySQL应该查看列是否包含MaleFemale,并返回任何结果。

请注意,如果可能的话,我不想根据代码的编写方式在查询中使用OR语句。

我试过下面的,但似乎不起作用。这些值来自具有EitherMaleFemale的表单中的选择框。

if ($postgender == "either")
{
    $male = "Male";
    $female = "Female";
    $postgenderuse = ($male || $female);
}
else {
    $postgenderuse = $postgender;
}
$query4 = mysql_query("SELECT * FROM tennis WHERE gender='$postgenderuse' ORDER BY playerid DESC LIMIT 0,20");

开始从语句创建查询,还检查表单是否发送了3个值中的一个(只是为了确保)

if ($postgender == "Either")
{
    $postgenderuse = " ( `gender`='Male' OR `gender`='Female' ) ";
}
elseif ($postgender == "Male" || $postgender == "Female") {
    $postgenderuse = " `gender`='".$postgender."' ";
}
else {
    die('Error, no gender selected');
}
$query4 = mysql_query("SELECT * FROM `tennis` WHERE ".$postgenderuse." ORDER BY `playerid` DESC LIMIT 0,20");

假设你用二进制术语来处理性别,只包括两个选项(男性、女性):

$sql = "SELECT * FROM tennis";
if(in_array($postgender, array("Male", "Female"))
{
     $sql .= " WHERE gender=".$postgender;
}
$sql .= " ORDER BY playerid DESC LIMIT 0,20)";
$query4 = mysql_query($sql);

如果是其中之一,则更改查询以进行通配符搜索。

从网球中选择*性别喜欢"$postgenderuse"

这样,当他们选择其中一种时,你可以将postgenderuse设置为%Sign.

尽管如此,在查询中只使用OR,并根据条件构建查询可能是一个更好的主意,例如:

if($postgender == "Male") {
   $condition = "WHERE gender='Male'";
} else if($postgender == "Female") {
   $condition = "WHERE gender='Female'";
} else {
   $condition = "";
}
$query = "SELECT * FROM tennis " . $condition . " ORDER BY BLAH";

无论如何,任何一种方式都应该奏效。能够从条件语句构造查询是php功能的一部分。

~ Dan

如果您对字段gender使用Bitwise而不是String,那么您尝试过的解决方案就会起作用。

我建议使用SQL IN函数。类似于:

$query = "SELECT * FROM tennis WHERE gender IN ('" + implode("', '", $postGenderArray) + "')";