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/cn.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灯, 水草

请输入看板名称,例如:Tech_Job站内搜寻

TOP