Re: [請益] 複選的限制查詢

看板PHP作者 (請勿忘記密碼)時間18年前 (2007/07/01 01:58), 編輯推噓0(002)
留言2則, 1人參與, 最新討論串2/2 (看更多)
※ 引述《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
LIKE '黃%',這會比 LIKE '%黃%'的查詢速度快。
07/01 02:02, 2F
文章代碼(AID): #16XfdVL8 (PHP)
討論串 (同標題文章)
本文引述了以下文章的的內容:
完整討論串 (本文為第 2 之 2 篇):
文章代碼(AID): #16XfdVL8 (PHP)