我想选择返回值的行。如果他们在选择框中选择了Male
或Female
,我希望它搜索它。那部分工作正常。然而,如果他们选择Either
,我想说MySQL应该查看列是否包含Male
或Female
,并返回任何结果。
请注意,如果可能的话,我不想根据代码的编写方式在查询中使用OR语句。
我试过下面的,但似乎不起作用。这些值来自具有Either
、Male
或Female
的表单中的选择框。
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) + "')";