Heim Backend-Entwicklung PHP-Tutorial Yii2.0 PHP verwendet Sphinx

Yii2.0 PHP verwendet Sphinx

Apr 18, 2018 pm 01:36 PM
php sphinx

Dieser Artikel stellt die Verwendung von Sphinx in Yii2.0 PHP vor. Er hat einen gewissen Referenzwert. Jetzt kann ich ihn mit allen teilen.



[php]Klartext anzeigen


  1. 1 .Führen Sie zunächst die Sphinxapi-Klassendatei in Yii2.0 ein. Die Schritte zur Einführung sind:

  2. (1) Erstellen Sie einen neuen Ordner libs in Legen Sie im Stammverzeichnis die Klassendatei sphinxapi.php im libs-Ordner ab.

  3. (2.) Fügen Sie dann in der web.php-Konfiguration im Konfigurationsordner des Stammverzeichnisses Yii::$classMap hinzu ['SphinxClient'] = '@app/libs/sphinxapi.php'

  4. (3.) Verwendung im Controller use SphinxClient; (4.) Ich habe hier zwei Tabellen verwendet, die Blogtabelle ex_blog und die Blogkategorietabelle ex_blog_type



[php]

Klartext anzeigen


    HTML-Seitenverarbeitung
  1. /* 
     * Sphinx搜索 
     */  
    public function actionSearch(){  
        //判断是否是POST提交  
        if(\Yii::$app->request->isPost){  
            $title = \Yii::$app->request->post('title');  
            //$author = \Yii::$app->request->post('author');  
            //$type_name = \Yii::$app->request->post('type_name');  
            $sphinx = new SphinxClient();  
            $sphinx->SetServer('127.0.0.1',9312);  
              
            //SPH_MATCH_ALL匹配所有查询词(默认模式)  
            $sphinx->SetMatchMode ( SPH_MATCH_ALL);  
            //匹配查询词中的任意一个  
            $sphinx->SetMatchMode ( SPH_MATCH_ANY);  
            //将整个查询看作一个词组,要求按顺序完整匹配  
            $sphinx->SetMatchMode ( SPH_MATCH_PHRASE);  
              
            $data = $sphinx->Query("$title","*");  
            //判断键值是否存在  
            if(!array_key_exists("matches",$data)){  
                exit("没有检索到您需要的信息");  
            }  
            // 1.Matches中就是查询的结果了,但是仿佛不是我们想要的数据。  
            // 2.根据官方的说明是Sphinx并没有连接到MySQL去取数据,只是根据它自己的索引内容进行计算;  
            // 3.因此如果想用Sphinx提供的API去取得我们想要的数据,还必须以查询的结果为依据(也就是ID为依据);  
            // 4.根据ID再次查询MySQL从而得到我们想要的数据。  
            //获取主键 (这里的主键就是数据在数据库中的自增ID) 通过ID在根据数据库 查询出数据  
            $key = array_keys($data['matches']);  
            //把数组元素组合为一个字符串  
            $key = join(',',$key);  
            //根据获取到的ID在查询数据库  
            $query = new \yii\db\Query();  
            //使用框架中的in 哈希格式 来检索  
            $blogInfo = $query->from(['b'=>'ex_blog','bt'=>'ex_blog_type'])->where(['id'=>[$key]])->all();  
            //将数组转换为Json类型  
            echo json_encode($blogInfo);  
        }else{  
            echo "非正常提交";  
        }  
    }
    Nach dem Login kopieren



[ php]

Einfache Kopie anzeigen

  1. <script>  
            function search(){  
                //获取搜索的数据  
                var title = $("#title").val();  
                var author = $("#author").val();  
                var type_name = $("#type_name").val();  
                //发送AJAX请求  
                $.ajax({  
                    url:"?r=sphinx/search",  
                    data:{title:title,author:author,type_name:type_name},  
                    type:"POST",  
                    success:function(msg){  
                        //alert(msg);  
                        //将JSON数据转换为对象  
                        obj = eval("("+msg+")");  
                        var table = &#39;&#39;;  
                        table += &#39;<table border="1" align="center" width="800" style="text-align: center">&#39;  
                            table += &#39;<tr id="tr">&#39;;  
                            table += &#39;<td>编号</td>&#39;;  
                            table += &#39;<td>标题</td>&#39;;  
                            table += &#39;<td>作者</td>&#39;;  
                            table += &#39;<td>类型</td>&#39;;  
                            table += &#39;<td>封面</td>&#39;;  
                            table += &#39;<td>添加时间</td>&#39;;  
                            table += &#39;<td>操作</td>&#39;;  
                            table += &#39;</tr>&#39;;  
                             for(var i in obj){  
                                 table += "<tr class=&#39;content&#39;>"  
                                 table += "<td>"+obj[i].id+"</td>";  
                                 table += "<td>"+obj[i].title+"</td>";  
                                 table += "<td>"+obj[i].author+"</td>";  
                                 table += "<td>"+obj[i].type_name+"</td>";  
                                 table += &#39;<td><img src=&#39;+obj[i].pic+&#39; alt="封面" width="50" height="50"></td>&#39;;  
                                 table += "<td>"+obj[i].time+"</td>";  
                                 table += "<td> <a href=&#39;&#39;>删除</a> | <a href=&#39;&#39;>编辑</a> </td>";  
                                 table += "</tr>"  
                             }  
                        table += &#39;</table>&#39;;  
                        //将表格赋值到页面  
                        $("#table").html(table);  
                        //将原有的内容移除  
                        //$(".content").remove();  
                        //将返回的数据追加到原来位置  
                        //$("#tr").after(tr);  
                    }  
                });  
            }  
        </script>
    Nach dem Login kopieren

显示数据用的p




[php] view plain copy


  1. <p id="table"></p>
    Nach dem Login kopieren

相关推荐:

Yii2 的控制台命令

php中如何使用sphinx搜索引擎

Yii框架中sphinx索引配置方法解析

Das obige ist der detaillierte Inhalt vonYii2.0 PHP verwendet Sphinx. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

CakePHP-Projektkonfiguration CakePHP-Projektkonfiguration Sep 10, 2024 pm 05:25 PM

In diesem Kapitel werden wir die Umgebungsvariablen, die allgemeine Konfiguration, die Datenbankkonfiguration und die E-Mail-Konfiguration in CakePHP verstehen.

PHP 8.4 Installations- und Upgrade-Anleitung für Ubuntu und Debian PHP 8.4 Installations- und Upgrade-Anleitung für Ubuntu und Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 bringt mehrere neue Funktionen, Sicherheitsverbesserungen und Leistungsverbesserungen mit einer beträchtlichen Menge an veralteten und entfernten Funktionen. In dieser Anleitung wird erklärt, wie Sie PHP 8.4 installieren oder auf PHP 8.4 auf Ubuntu, Debian oder deren Derivaten aktualisieren. Obwohl es möglich ist, PHP aus dem Quellcode zu kompilieren, ist die Installation aus einem APT-Repository wie unten erläutert oft schneller und sicherer, da diese Repositorys in Zukunft die neuesten Fehlerbehebungen und Sicherheitsupdates bereitstellen.

CakePHP Datum und Uhrzeit CakePHP Datum und Uhrzeit Sep 10, 2024 pm 05:27 PM

Um in cakephp4 mit Datum und Uhrzeit zu arbeiten, verwenden wir die verfügbare FrozenTime-Klasse.

CakePHP-Datei hochladen CakePHP-Datei hochladen Sep 10, 2024 pm 05:27 PM

Um am Datei-Upload zu arbeiten, verwenden wir den Formular-Helfer. Hier ist ein Beispiel für den Datei-Upload.

CakePHP-Routing CakePHP-Routing Sep 10, 2024 pm 05:25 PM

In diesem Kapitel lernen wir die folgenden Themen im Zusammenhang mit dem Routing kennen.

Besprechen Sie CakePHP Besprechen Sie CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP ist ein Open-Source-Framework für PHP. Es soll die Entwicklung, Bereitstellung und Wartung von Anwendungen erheblich vereinfachen. CakePHP basiert auf einer MVC-ähnlichen Architektur, die sowohl leistungsstark als auch leicht zu verstehen ist. Modelle, Ansichten und Controller gu

So richten Sie Visual Studio-Code (VS-Code) für die PHP-Entwicklung ein So richten Sie Visual Studio-Code (VS-Code) für die PHP-Entwicklung ein Dec 20, 2024 am 11:31 AM

Visual Studio Code, auch bekannt als VS Code, ist ein kostenloser Quellcode-Editor – oder eine integrierte Entwicklungsumgebung (IDE) –, die für alle gängigen Betriebssysteme verfügbar ist. Mit einer großen Sammlung von Erweiterungen für viele Programmiersprachen kann VS Code c

CakePHP erstellt Validatoren CakePHP erstellt Validatoren Sep 10, 2024 pm 05:26 PM

Der Validator kann durch Hinzufügen der folgenden zwei Zeilen im Controller erstellt werden.

See all articles