pbootcms网站模板|日韩1区2区|织梦模板||网站源码|日韩1区2区|jquery建站特效-html5模板网

  • <tfoot id='1lL8o'></tfoot>
    1. <i id='1lL8o'><tr id='1lL8o'><dt id='1lL8o'><q id='1lL8o'><span id='1lL8o'><b id='1lL8o'><form id='1lL8o'><ins id='1lL8o'></ins><ul id='1lL8o'></ul><sub id='1lL8o'></sub></form><legend id='1lL8o'></legend><bdo id='1lL8o'><pre id='1lL8o'><center id='1lL8o'></center></pre></bdo></b><th id='1lL8o'></th></span></q></dt></tr></i><div class="kyfoq2f" id='1lL8o'><tfoot id='1lL8o'></tfoot><dl id='1lL8o'><fieldset id='1lL8o'></fieldset></dl></div>
      <legend id='1lL8o'><style id='1lL8o'><dir id='1lL8o'><q id='1lL8o'></q></dir></style></legend>
      • <bdo id='1lL8o'></bdo><ul id='1lL8o'></ul>

        <small id='1lL8o'></small><noframes id='1lL8o'>

        使用 PDO 準備好的語句使用搜索字段中的多個關鍵

        LIKE query using multiple keywords from search field using PDO prepared statement(使用 PDO 準備好的語句使用搜索字段中的多個關鍵字進行 LIKE 查詢)
        <legend id='PcMAt'><style id='PcMAt'><dir id='PcMAt'><q id='PcMAt'></q></dir></style></legend>

        <tfoot id='PcMAt'></tfoot>
        • <i id='PcMAt'><tr id='PcMAt'><dt id='PcMAt'><q id='PcMAt'><span id='PcMAt'><b id='PcMAt'><form id='PcMAt'><ins id='PcMAt'></ins><ul id='PcMAt'></ul><sub id='PcMAt'></sub></form><legend id='PcMAt'></legend><bdo id='PcMAt'><pre id='PcMAt'><center id='PcMAt'></center></pre></bdo></b><th id='PcMAt'></th></span></q></dt></tr></i><div class="k73wvxu" id='PcMAt'><tfoot id='PcMAt'></tfoot><dl id='PcMAt'><fieldset id='PcMAt'></fieldset></dl></div>

                • <bdo id='PcMAt'></bdo><ul id='PcMAt'></ul>

                    <tbody id='PcMAt'></tbody>

                  <small id='PcMAt'></small><noframes id='PcMAt'>

                  本文介紹了使用 PDO 準備好的語句使用搜索字段中的多個關鍵字進行 LIKE 查詢的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

                  問題描述

                  網站用戶使用搜索表單來查詢產品數據庫.輸入的關鍵字搜索數據庫中產品的標題.

                  Site users use a search form to query a database of products. The keywords entered search the titles for the products in the database.

                      public function startSearch($keywords){
                          $keywords = preg_split('/[s]+/', $keywords);
                          $totalKeywords = count($keywords);
                  
                          foreach($keywords as $key => $keyword){
                              $search .= '%'.$keyword.'%';
                              if($key != ($totalKeywords)-1){
                                  $search .= ' AND itemTitle LIKE ';
                              }
                          }
                  $sql=$this->db->prepare("SELECT * FROM prodsTable WHERE itemTitle LIKE ?");
                  $sql->bindParam(1, $search);        
                  $sql->execute ();
                  $sql->fetchALL(PDO::FETCH_ASSOC);
                  

                  如果用戶輸入單個關鍵字,則搜索有效,但如果使用多個關鍵字,則查詢不會執行.

                  The search works if a user enters a single keyword, but if multiple keywords are used the query does not execute.

                  如果:$keywords = '蘋果 ipod';$search = '%apple% AND itemTitle LIKE %ipod%';

                  if: $keywords = 'apple ipod'; $search = '%apple% AND itemTitle LIKE %ipod%';

                  所以準備好的語句應該是這樣的:

                  So the prepared statement should look like this:

                  SELECT * FROM prodsTable WHERE itemTitle LIKE %apple% AND itemTitle LIKE %ipod%"

                  "SELECT * FROM prodsTable WHERE itemTitle LIKE %apple% AND itemTitle LIKE %ipod%"

                  如果返回的兩個產品的標題中都應包含apple"和ipod",則不會返回任何結果.

                  No results return when two products should return having both "apple" and "ipod" in their titles.

                  我做錯了什么?

                  推薦答案

                  預置語句保護您免受 sql 注入,因此參數中的 sql 代碼將不會被解釋.在調用 prepare() 之前,您必須使用正確數量的 AND itemTitle LIKE ? 構建一個 sql 查詢.

                  Prepared statements protect you from sql injection, so sql code in the parameters will not be interpreted. You will have to build a sql query with the correct number of AND itemTitle LIKE ? before calling prepare().

                    $keywords = preg_split('/[s]+/', $keywords);
                    $totalKeywords = count($keywords);
                    $query = "SELECT * FROM prodsTable WHERE itemTitle LIKE ?";
                  
                    for($i=1 ; $i < $totalKeywords; $i++){
                      $query .= " AND itemTitle LIKE ? ";
                    }
                  
                    $sql=$this->db->prepare($query);
                    foreach($keywords as $key => $keyword){
                      $sql->bindValue($key+1, '%'.$keyword.'%');
                    }
                    $sql->execute ();
                  

                  這篇關于使用 PDO 準備好的語句使用搜索字段中的多個關鍵字進行 LIKE 查詢的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

                  【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

                  相關文檔推薦

                  MySQLi prepared statement amp; foreach loop(MySQLi準備好的語句amp;foreach 循環)
                  Is mysqli_insert_id() gets record from whole server or from same user?(mysqli_insert_id() 是從整個服務器還是從同一用戶獲取記錄?)
                  PHP MySQLi doesn#39;t recognize login info(PHP MySQLi 無法識別登錄信息)
                  mysqli_select_db() expects exactly 2 parameters(mysqli_select_db() 需要 2 個參數)
                  Php mysql pdo query: fill up variable with query result(Php mysql pdo 查詢:用查詢結果填充變量)
                  MySQLI 28000/1045 Access denied for user #39;root#39;@#39;localhost#39;(MySQLI 28000/1045 用戶“root@“localhost的訪問被拒絕)
                  <i id='kxL2p'><tr id='kxL2p'><dt id='kxL2p'><q id='kxL2p'><span id='kxL2p'><b id='kxL2p'><form id='kxL2p'><ins id='kxL2p'></ins><ul id='kxL2p'></ul><sub id='kxL2p'></sub></form><legend id='kxL2p'></legend><bdo id='kxL2p'><pre id='kxL2p'><center id='kxL2p'></center></pre></bdo></b><th id='kxL2p'></th></span></q></dt></tr></i><div class="zvia8tv" id='kxL2p'><tfoot id='kxL2p'></tfoot><dl id='kxL2p'><fieldset id='kxL2p'></fieldset></dl></div>

                  1. <small id='kxL2p'></small><noframes id='kxL2p'>

                    <legend id='kxL2p'><style id='kxL2p'><dir id='kxL2p'><q id='kxL2p'></q></dir></style></legend>

                      <tfoot id='kxL2p'></tfoot>

                        <tbody id='kxL2p'></tbody>

                          • <bdo id='kxL2p'></bdo><ul id='kxL2p'></ul>

                          • 主站蜘蛛池模板: 阳光模拟试验箱_高低温试验箱_高低温冲击试验箱_快速温变试验箱|东莞市赛思检测设备有限公司 | 许昌奥仕达自动化设备有限公司 | 照相馆预约系统,微信公众号摄影门店系统,影楼管理软件-盟百网络 | 热风机_工业热风机生产厂家上海冠顶公司提供专业热风机图片价格实惠 | 一礼通 (www.yilitong.com)-企业礼品解决方案一站式服务平台 | 飞扬动力官网-广告公司管理软件,广告公司管理系统,喷绘写真条幅制作管理软件,广告公司ERP系统 | 稳尚教育加盟-打造高考志愿填报平台_新高考志愿填报加盟_学业生涯规划加盟 | 安全光栅|射频导纳物位开关|音叉料位计|雷达液位计|两级跑偏开关|双向拉绳开关-山东卓信机械有限公司 | 天一线缆邯郸有限公司_煤矿用电缆厂家_矿用光缆厂家_矿用控制电缆_矿用通信电缆-天一线缆邯郸有限公司 | 地埋式垃圾站厂家【佳星环保】小区压缩垃圾中转站转运站 | 气动|电动调节阀|球阀|蝶阀-自力式调节阀-上海渠工阀门管道工程有限公司 | 广州市哲铭油墨涂料有限公司,水性漆生产研发基地 | 驾驶人在线_专业学车门户网站| 东莞压铸厂_精密压铸_锌合金压铸_铝合金压铸_压铸件加工_东莞祥宇金属制品 | 钢格板_钢格栅_格栅板_钢格栅板 - 安平县鑫拓钢格栅板厂家 | elisa试剂盒价格-酶联免疫试剂盒-猪elisa试剂盒-上海恒远生物科技有限公司 | 江苏远邦专注皮带秤,高精度皮带秤,电子皮带秤研发生产 | 步进电机_agv电机_伺服马达-伺服轮毂电机-和利时电机 | 继电器模组-IO端子台-plc连接线-省配线模组厂家-世麦德 | 防水套管|柔性防水套管|伸缩器|伸缩接头|传力接头-河南伟创管道 防水套管_柔性防水套管_刚性防水套管-巩义市润达管道设备制造有限公司 | 广州中央空调回收,二手中央空调回收,旧空调回收,制冷设备回收,冷气机组回收公司-广州益夫制冷设备回收公司 | 青岛侦探_青岛侦探事务所_青岛劝退小三_青岛婚外情取证-青岛王军侦探事务所 | 天津试验仪器-电液伺服万能材料试验机,恒温恒湿标准养护箱,水泥恒应力压力试验机-天津鑫高伟业科技有限公司 | 检验科改造施工_DSA手术室净化_导管室装修_成都特殊科室建设厂家_医疗净化工程公司_四川华锐 | 流量检测仪-气密性检测装置-密封性试验仪-东莞市奥图自动化科技有限公司 | 铝机箱_铝外壳加工_铝外壳厂家_CNC散热器加工-惠州市铂源五金制品有限公司 | 热缩管切管机-超声波切带机-织带切带机-无纺布切布机-深圳市宸兴业科技有限公司 | 模具ERP_模具管理系统_模具mes_模具进度管理_东莞市精纬软件有限公司 | 右手官网|右手工业设计|外观设计公司|工业设计公司|产品创新设计|医疗产品结构设计|EMC产品结构设计 | 整合营销推广|营销网络推广公司|石家庄网站优化推广公司|智营销 好物生环保网、环保论坛 - 环保人的学习交流平台 | 刮板输送机,粉尘加湿搅拌机,螺旋输送机,布袋除尘器 | 精雕机-火花机-精雕机 cnc-高速精雕机-电火花机-广东鼎拓机械科技有限公司 | 篮球地板厂家_舞台木地板品牌_体育运动地板厂家_凯洁地板 | 磁力抛光机_磁力研磨机_磁力去毛刺机_精密五金零件抛光设备厂家-冠古科技 | 山东led显示屏,山东led全彩显示屏,山东LED小间距屏,临沂全彩电子屏-山东亚泰视讯传媒有限公司 | 云阳人才网_云阳招聘网_云阳人才市场_云阳人事人才网_云阳人家招聘网_云阳最新招聘信息 | 铁素体测量仪/检测仪/铁素体含量测试仪-苏州圣光仪器有限公司 | 匀胶机旋涂仪-声扫显微镜-工业水浸超声-安赛斯(北京)科技有限公司 | 水厂自动化|污水处理中控系统|水利信息化|智慧水务|智慧农业-山东德艾自动化科技有限公司 | 泰来华顿液氮罐,美国MVE液氮罐,自增压液氮罐,定制液氮生物容器,进口杜瓦瓶-上海京灿精密机械有限公司 | 低噪声电流前置放大器-SR570电流前置放大器-深圳市嘉士达精密仪器有限公司 |