PHP 板


LINE

看板 PHP  RSS
※ 引述《rjackie (向前走,才知道轉角)》之銘言: : <?php : $keys = explode(" ",$_GET['p_search']); : $term = "%".$_GET['p_search']."%"; : foreach ($keys as $word) { : $search_name[] = 'product_info.name LIKE ?'; : $search_summary[] = 'product_info.summary LIKE ?'; : $search_model[] = 'product_standard_data.model LIKE ?'; : $arguments[] = '%'.$word.'%'; : : } : $product_info_auto_sql = $db->prepare(" : SELECT : product_info.name : FROM : product_info,product_standard_data : WHERE : product_info.no = product_standard_data.product_no : AND : ".implode(' AND ', $search_name)." : OR : ".implode(' AND ', $search_summary)." : OR : ".implode(' AND ', $search_model)." : AND : product_info.status = '1' GROUP BY product_info.name order by product_in : fo.sequence DESC, product_info.name DESC"); : $product_info_auto_sql->execute($arguments); : while($product_info_auto_row = $product_info_auto_sql->fetch()){ : echo $product_info_auto_row['name']; : } : ?> : : 問題在於無法在execute的時候會發生 : Invalid parameter number: number of bound variables does not match number : 有嘗試過arguments使用三次當然一定會錯,或是將$term變成陣列方式但還是有問題。 : 不知道這情況是否有什麼建議作法呢? : 感恩 你的WHERE字串,串起來後好像都沒有括號? 只看到 implode 的括號,但是字串串起來後,應該是沒有括號。 類似 WHERE condA1 AND condA2 OR condB1 AND condB2 OR condC1 AND cond C2 ... 一堆AND跟OR擠在一起,這樣有問題吧。 應該改成 WHERE (product_no=123 AND status=1) AND ( (condA1 AND condA2) /*search_name*/ OR (condB1 AND condB2) /*search_summary*/ OR (condC1 AND condC2) /*search_model*/ ) 而且可以使用名稱變數,不使用問號。 SELECT ... WHERE col1=:col1 AND col2=:col2 下面只使用 search_name 跟 search_model , 僅供參考。 foreach ($keys as $key=>$word) { $search_name[] = 'product_info.name LIKE :word' . $key; /* $search_name = array( 'product_info.name LIKE :word1', 'product_info.name LIKE :word2', ... ); */ $search_model[] = 'product_standard_data.model LIKE :word' . $key; /* $search_model = array( 'product_standard_data.model LIKE :word1', 'product_standard_data.model LIKE :word2', ... ); */ } $whName = implode(' AND ', $search_name); //product_info.name LIKE :word1 AND product_info.name LIKE :word2 $whModel = implode(' AND ', $search_model); //類似上面 $sql = " SELECT ... WHERE (info.no = standard_data.product_no AND info.status = '1') AND ( (" . $whName . ") OR (" . $whModel . ") OR (" . $whSummary . ") ) "; $result = $dbh->prepare($sql); foreach($keys as $key=>$word){ $keystr = 'word' . $key; //word1, word2... $$keystr = $word; //注意符號是兩個 $result->bindParam(':'.$keystr, $$keystr); } $result->execute(); 我之前寫過的大概是這樣。 會用兩個符$符號,記得是因為 bindParam 使用的變數不允許重複。 因為 bindParam 的意思就是把變數跟值綁定在一起, 綁定了,就不能改,所以不能跑迴圈。 $$keystr 會先變成 $word1 或 $word2, 然後值就是該次的 $word 不保證成功,可能要再多測試。 --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 1.171.155.68
※ 文章網址: https://webptt.com/m.aspx?n=bbs/PHP/M.1486824997.A.2E0.html ※ 編輯: anawak (1.171.155.68), 02/11/2017 23:05:41
1F:推 rjackie: 哇!感謝經驗分享,其中很多是沒有想到的概念,我研究一下 02/11 23:16
2F:→ MOONRAKER: 可以用assoc array 就不用$$了 02/11 23:29
3F:→ mimikillua: "bindParam 使用的變數不允許重複"這句幫大忙了 04/25 17:05
4F:→ mimikillua: 我用同一個變數搜尋不同column 怎樣改都出錯 04/25 17:07







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:Boy-Girl站內搜尋

TOP