Re: [請益] 複選的限制查詢
※ 引述《yo0401 (羽無倫)》之銘言:
: 小弟我想做複選的限制查詢
: 但是第一次做,不知道有沒有更好的寫法
: 我的想法是:
: 譬如衣服的顏色 黃、綠、紅
: SELECT * FROM 資料表 WHERE 欄位 like XXX $limit;
: $limit="limit $color1 $color2 $color3";
: if (empty($color=紅){
: $color1=null;
: }else{
: $color1="color=紅 and"
: }
: .
: .
: .
: (沒測試過,只是有這個想法,上面的想法還有很多問題還待解決)
: 不知道有沒有人有更好的寫法,或是有參考的網站(希望是中文)
: 我的目的是要限制查詢的條件,而且是複選
這個問題要從兩方面來看,一個是如何在php裡面取得表單欄位的複選資料,
一個是如何寫出SQL query。
在HTML表單裡面要做複選通常是使用核取方塊(checkbox):
<form action="act.php" method="get">
顏色:
<input type="checkbox" name="color[]" value="黃" />
<input type="checkbox" name="color[]" value="綠" />
<input type="checkbox" name="color[]" value="紅" />
<input type="submit">
</form>
注意欄位名稱是color[],有了[],php會幫你把這些欄位資料轉成陣列,
在act.php裡面你可以透過$_GET['color']來取得使用者勾選的顏色。
如果使用者勾選了黃和綠,$_GET['color']會是
array(
0 => '黃',
1 => '綠'
)
如果都沒有勾選,$_GET['color']這個變數就不存在(這很重要,是
不存在,而不是一個空的陣列,這兩者差異很大)。
在SQL query方面,首先LIMIT這個語法(適用mysql, postgresql)
的使用方式跟你原本設想的並不一樣,它是用來限制傳回的資料筆數
而不是過濾哪些資料會被傳回。如果你使用IN語法的話,若使用者
勾選黃色綠色,那麼:
SELECT ..... WHERE color IN ('黃', '綠')
便會找出color欄位值"等於"黃或者綠的資料。所以問題變成如何組出
以上的SQL。你可以使用:
$query = "SELECT...WHERE color IN ('".implode("','", $_GET['color'])."')";
但是這是假設使用者至少有勾選一項顏色。如果完全沒勾選就送出,
如同前面所述,此時$_GET['color']並不存在,因此implode()那裡
就會出現錯誤訊息,指出$_GET['color']不是一個有效的陣列。
(如何處理萬一使用者沒有勾選任何顏色的狀況就不討論了。
提示:isset())。
但是IN語法只能找出欄位值完全符合的資料,如果要找出欄位值
"包含"黃或者綠的資料,那得改用LIKE搭配萬用字元。
SELECT...WHERE color LIKE '%黃%' OR color LIKE '%綠%'
會找出color欄位值"包含"黃或者綠的資料。要組出這個SQL,可以:
$query = "SELECT...WHERE 1 = 0 ";
foreach($_GET['color'] as $color) {
$query .= (" OR color LIKE '%".$color."%' ");
}
這會組出:
SELECT...WHERE 1 = 0 OR color LIKE '%黃%' OR color LIKE '%綠%'
你可能會覺得那個 1 = 0 是做啥的。這算是個撇步,它可以讓你在組
出後面的OR...的時候不用考慮現在不是在陣列的第一個元素(是的話
就不能加上OR,不是才能加上OR,否則組出來的字串會有問題)。
mysql本身有最佳化功能,會把1=0這種顯然不成立的條件忽略掉。
同樣,這裡也沒有考慮萬一使用者沒有勾選任何顏色的狀況。
--
是說後半段其實比較適合丟去database板。
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 220.132.153.19
→
07/01 02:02, , 1F
07/01 02:02, 1F
→
07/01 02:02, , 2F
07/01 02:02, 2F
討論串 (同標題文章)
PHP 近期熱門文章
PTT數位生活區 即時熱門文章