,我有我的困惑我怎麼能解決這個問題的行爲SQL語句...PHP/MySQL的:從不同的列
我有一個表「favcolor」有4列名爲「POT1」 「pot2」,「pot3」,「pot4」。 在這個列是飲料的ID。
當我在「selectbox1」(「limonade」)中選擇飲料時:Energy/value =「5」。 在「selectbox2」(「limonade2」)中,我選擇了飲料:Mezzo/value =「3」。 它生成這個SQL語句:
"SELECT * FROM favcolor WHERE pot1= 5 AND pot2= 3" - i get 15 hits.
現在,我在 「selectbox1」 選擇( 「limonade」)的飲料:女中音/值= 「3」。 然後在「selectbox2」(「limonade2」)中選擇飲料:Energy/value =「5」。 現在產生這樣的SQL語句:
"SELECT * FROM favcolor WHERE pot1= 3 AND pot2= 5" - i get 7 hits.
但我試圖找到一個解決方案,我得到的,其中「能源」和「女中音」的存在,所有命中無論他們是否出現在電位器1,POT2,POT3或Pot4。
我希望你能幫我找到這個「問題」的解決方案。
爲了更好地理解這裏是我當前的代碼:
<form method="post"action="./usercolor.php">
<input type="checkbox" id="colorred" name="colorred" value="1"/>red</td>
<input type="checkbox" id="colorblue" name="colorblue" value="1"/>blue</td>
<input type="checkbox" id="coloryellow" name="coloryellow" value="1"/>yellow</td>
<input type="checkbox" id="colorgreen" name="colorgreen" value="1"/>green</td>
<input type="checkbox" id="colorblack" name="colorblack" value="1"/>black</td>
</select name="limonade">
<option value="1">Cola</option>
<option value="2">Fanta</option>
<option value="3">Mezzo</option>
<option value="4">Sprite</option>
<option value="5">Energy</option>
</select>
</select name="limonade2">
<option value="1">Cola</option>
<option value="2">Fanta</option>
<option value="3">Mezzo</option>
<option value="4">Sprite</option>
<option value="5">Energy</option>
</select>
</select name="limonade3">
<option value="1">Cola</option>
<option value="2">Fanta</option>
<option value="3">Mezzo</option>
<option value="4">Sprite</option>
<option value="5">Energy</option>
</select>
</select name="limonade4">
<option value="1">Cola</option>
<option value="2">Fanta</option>
<option value="3">Mezzo</option>
<option value="4">Sprite</option>
<option value="5">Energy</option>
</select>
<input type="submit" value="SEARCH"/>
</form>
的PHP代碼:
$whereArr = Array();
if (isset($_POST["colorred"]) && $_POST["colorred"]==1) $whereArr[] = "red=1";
if (isset($_POST["colorblue"]) && $_POST["colorblue"]==1) $whereArr[] = "blue=1";
if (isset($_POST["colorgreen"]) && $_POST["colorgreen"]==1) $whereArr[] = "green=1";
if (isset($_POST["coloryellow"]) && $_POST["coloryellow"]==1) $whereArr[] = "yellow=1";
if (isset($_POST["colorblack"]) && $_POST["colorblack"]==1) $whereArr[] = "black=1";
$sql = "SELECT * FROM favcolor WHERE " . implode(" AND ", $whereArr);
if (empty($whereArr)) {
if($_POST["limonade"] > 0) $sql .= ' pot1 = ' . $_POST["limonade"];
if($_POST["limonade2"] > 0) $sql .= ' pot2 = ' . $_POST["limonade2"];
if($_POST["limonade3"] > 0) $sql .= ' pot3 = ' . $_POST["limonade3"];
if($_POST["limonade4"] > 0) $sql .= ' pot4 = ' . $_POST["limonade4"];
}
else {
if($_POST["limonade"] > 0) $sql .= ' and pot1 = ' . $_POST["limonade"];
if($_POST["limonade2"] > 0) $sql .= ' and pot2 = ' . $_POST["limonade2"];
if($_POST["limonade3"] > 0) $sql .= ' and pot3 = ' . $_POST["limonade3"];
if($_POST["limonade4"] > 0) $sql .= ' and pot4 = ' . $_POST["limonade4"];
}
表:
User |Red |Blue |Yellow |Green |Black
Klaus |0 |1 |1 |0 |0
Jessy |1 |0 |1 |0 |1
Andy |1 |1 |0 |0 |0
Alex |0 |0 |0 |1 |1
Denis |1 |1 |0 |0 |1
我想你正在尋找OR而不是AND? – Naruto 2015-03-19 10:07:03
請參閱標準化。 – Strawberry 2015-03-19 10:40:10