Heim PHP-Framework Denken Sie an PHP ThinkPHP-Datenbankbetriebsansichtsabfrage, Unterabfrage, native Abfrage

ThinkPHP-Datenbankbetriebsansichtsabfrage, Unterabfrage, native Abfrage

Feb 02, 2021 pm 03:25 PM
thinkphp

Die folgende Tutorial-Kolumne von thinkphp führt Sie in die Ansichtsabfrage, Unterabfrage und native Abfrage von ThinkPHP-Datenbankoperationen ein. Ich hoffe, dass sie für Freunde in Not hilfreich ist!

Ansichtsabfrage

Ansichtsabfrage kann Mehrtabellenabfragen implementieren, die nicht auf Datenbankansichten basieren, und erfordert nicht, dass die Datenbank Ansichten unterstützt:

Db::view('User','id,name')
    ->view('Profile','truename,phone,email','Profile.user_id=User.id')
    ->view('Score','score','Score.user_id=Profile.id')
    ->where('score','>',80)
    ->select();
Nach dem Login kopieren

Die generierte SQL-Anweisung ähnelt:

SELECT User.id,User.name,Profile.truename,Profile.phone,Profile.email,Score.score 
FROM think_user User 
INNER JOIN think_profile Profile ON Profile.user_id=User.id 
INNER JOIN think_socre Score ON Score.user_id=Profile.id 
WHERE Score.score > 80
Nach dem Login kopieren

 Beachten Sie, dass bei der Ansichtsabfrage die Tabellen- und Join-Methoden nicht aufgerufen werden müssen. Beim Aufrufen der Where- und Order-Methoden müssen Sie nur den Feldnamen verwenden, ohne den Tabellennamen hinzuzufügen.

INNER-Join-Abfrage wird standardmäßig verwendet. Wenn Sie sie ändern müssen, können Sie Folgendes verwenden:

Db::view('User','id,name')
    ->view('Profile','truename,phone,email','Profile.user_id=User.id','LEFT')
    ->view('Score','score','Score.user_id=Profile.id','RIGHT')
    ->where('score','>',80)
    ->select();
Nach dem Login kopieren

Die generierte SQL-Anweisung ähnelt:

SELECT User.id,User.name,Profile.truename,Profile.phone,Profile.email,Score.score 
FROM think_user User 
LEFT JOIN think_profile Profile ON Profile.user_id=User.id 
RIGHT JOIN think_socre Score ON Score.user_id=Profile.id 
WHERE Score.score > 80
Nach dem Login kopieren

Sie können einen Alias ​​verwenden:

Db::view('User',['id'=>'uid','name'=>'account'])
    ->view('Profile','truename,phone,email','Profile.user_id=User.id')
    ->view('Score','score','Score.user_id=Profile.id')
    ->where('score','>',80)
    ->select();
Nach dem Login kopieren

Die generierte SQL-Anweisung wird :

SELECT User.id AS uid,User.name AS account,Profile.truename,Profile.phone,Profile.email,Score.score 
FROM think_user User 
INNER JOIN think_profile Profile ON Profile.user_id=User.id 
INNER JOIN think_socre Score ON Score.user_id=Profile.id 
WHERE Score.score > 80
Nach dem Login kopieren

Sie können eine Array-Methode verwenden, um den Tabellennamen und den Alias ​​zu definieren, zum Beispiel:

Db::view(['think_user'=>'member'],['id'=>'uid','name'=>'account'])
    ->view('Profile','truename,phone,email','Profile.user_id=member.id')
    ->view('Score','score','Score.user_id=Profile.id')
    ->where('score','>',80)
    ->select();
Nach dem Login kopieren

Die generierte SQL-Anweisung wird zu:

SELECT member.id AS uid,member.name AS account,Profile.truename,Profile.phone,Profile.email,Score.score 
FROM think_user member 
INNER JOIN think_profile Profile ON Profile.user_id=member.id 
INNER JOIN think_socre Score ON Score.user_id=Profile.id 
WHERE Score.score > 80
Nach dem Login kopieren

Unterabfrage

Erstellen Sie zunächst die Unterabfrage SQL Verwenden Sie die folgenden drei Methoden, um die Unterabfrage zu erstellen.

1. Verwenden Sie die Select-Methode

Wenn der Parameter der Select-Methode falsch ist, bedeutet dies, dass keine Abfrage ausgeführt wird und nur das konstruierte SQL zurückgegeben wird. Beispiel:

$subQuery = Db::table('think_user')    
->field('id,name')    
->where('id','>',10)    
->select(false);
Nach dem Login kopieren

Die generierte Unterabfrage Ergebnis ist:

SELECT `id`,`name` FROM `think_user` WHERE `id` > 10
Nach dem Login kopieren
Nach dem Login kopieren

2. Verwenden Sie die fetchSql-Methode

Die fetchSql-Methode bedeutet, dass sie nicht nur die konstruierte SQL-Anweisung zurückgibt, sondern auch alle CURD-Abfragen unterstützt. Das von

$subQuery = Db::table('think_user')    
->field('id,name')    
->where('id','>',10)    
->fetchSql(true)    
->select();
Nach dem Login kopieren

generierte Unterabfrageergebnis lautet:

SELECT `id`,`name` FROM `think_user` WHERE `id` > 10
Nach dem Login kopieren
Nach dem Login kopieren

3. Verwenden Sie buildSql, um eine Unterabfrage zu erstellen buildSql-Methode, und es generiert lediglich die SQL-Anweisung für diese Abfrage (um Verwirrung zu vermeiden, werden auf beiden Seiten der SQL Klammern hinzugefügt), und dann rufen wir sie in nachfolgenden Abfragen direkt auf.  Es ist zu beachten, dass Sie bei Verwendung der ersten beiden Methoden selbst „Klammern“ hinzufügen müssen.

Dann verwenden Sie die Unterabfrage, um eine neue Abfrage zu erstellen:

$subQuery = Db::table('think_user')    
->field('id,name')    
->where('id','>',10)    
->buildSql();
Nach dem Login kopieren
Die generierte SQL-Anweisung lautet:

4. Verwenden Sie Abschlüsse, um die Unterabfrage zu erstellen

IN/NOT IN und EXISTS/ NOT-Abfragen wie EXISTS können Abschlüsse direkt als Unterabfragen verwenden, zum Beispiel:

( SELECT `id`,`name` FROM `think_user` WHERE `id` > 10 )
Nach dem Login kopieren
Die generierte SQL-Anweisung lautet
Db::table($subQuery.' a')    
->where('a.name','like','thinkphp')    
->order('id','desc')    
->select();
Nach dem Login kopieren
SELECT * FROM ( SELECT `id`,`name` FROM `think_user` WHERE `id` > 10 ) a WHERE a.name LIKE 'thinkphp' ORDER BY `id` desc
Nach dem Login kopieren
Die generierte SQL-Anweisung lautet
Db::table('think_user')    
->where('id','IN',function($query){        
$query->table('think_profile')->where('status',1)->field('id');
    })    
    ->select();
Nach dem Login kopieren

Native Abfrage

Die DB-Klasse unterstützt native SQL-Abfragen Zu den Operationen gehören hauptsächlich die folgenden zwei Methoden: Abfragemethode

Abfragemethode wird zum Ausführen von SQL-Abfragevorgängen verwendet. Wenn die Daten ungültig sind oder die Abfrage falsch ist, gibt sie „false“ zurück, andernfalls gibt sie die Abfrage zurück Ergebnisdatensatz (identisch mit der Auswahlmethode). Verwendungsbeispiel:

SELECT * FROM `think_user` WHERE `id` IN ( SELECT `id` FROM `think_profile` WHERE `status` = 1 )
Nach dem Login kopieren
 Wenn Sie derzeit eine verteilte Datenbank verwenden und die Lese- und Schreibtrennung einrichten, wird die Abfragemethode immer auf dem Leseserver ausgeführt, sodass die Abfragemethode unabhängig von Ihrer SQL-Anweisung dem Lesevorgang entspricht Was ist es.

execute-Methode

execute wird für SQL-Vorgänge zum Aktualisieren und Schreiben von Daten verwendet. Wenn die Daten ungültig sind oder die Abfrage falsch ist, gibt sie „false“ zurück, andernfalls wird die Anzahl der betroffenen Datensätze zurückgegeben. Verwendungsbeispiel:

Db::table('think_user')    
->where(function($query){        
$query->table('think_profile')->where('status',1);
    },'exists')    
    ->find();
Nach dem Login kopieren
 Wenn Sie derzeit eine verteilte Datenbank verwenden und eine Lese-Schreib-Trennung einrichten, wird die Ausführungsmethode immer auf dem Schreibserver ausgeführt, sodass die Ausführungsmethode unabhängig von Ihrem SQL-Vorgang Schreibvorgängen entspricht eine Aussage.

Parameterbindung

unterstützt die Verwendung der Parameterbindung in nativen Abfragen, einschließlich Fragezeichen-Platzhaltern oder benannten Platzhaltern, zum Beispiel:

SELECT * FROM `think_user` WHERE EXISTS ( SELECT * FROM `think_profile` WHERE `status`= 1 )
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonThinkPHP-Datenbankbetriebsansichtsabfrage, Unterabfrage, native Abfrage. 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)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
1 Monate 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)

So führen Sie das Thinkphp-Projekt aus So führen Sie das Thinkphp-Projekt aus Apr 09, 2024 pm 05:33 PM

Um das ThinkPHP-Projekt auszuführen, müssen Sie: Composer installieren, das Projektverzeichnis aufrufen und http://localhost:8000 aufrufen.

Es gibt mehrere Versionen von thinkphp Es gibt mehrere Versionen von thinkphp Apr 09, 2024 pm 06:09 PM

ThinkPHP verfügt über mehrere Versionen, die für verschiedene PHP-Versionen entwickelt wurden. Zu den Hauptversionen gehören 3.2, 5.0, 5.1 und 6.0, während Nebenversionen dazu dienen, Fehler zu beheben und neue Funktionen bereitzustellen. Die neueste stabile Version ist ThinkPHP 6.0.16. Berücksichtigen Sie bei der Auswahl einer Version die PHP-Version, die Funktionsanforderungen und den Community-Support. Für optimale Leistung und Support wird empfohlen, die neueste stabile Version zu verwenden.

So führen Sie thinkphp aus So führen Sie thinkphp aus Apr 09, 2024 pm 05:39 PM

Schritte zum lokalen Ausführen von ThinkPHP Framework: Laden Sie ThinkPHP Framework herunter und entpacken Sie es in ein lokales Verzeichnis. Erstellen Sie einen virtuellen Host (optional), der auf das ThinkPHP-Stammverzeichnis verweist. Konfigurieren Sie Datenbankverbindungsparameter. Starten Sie den Webserver. Initialisieren Sie die ThinkPHP-Anwendung. Greifen Sie auf die URL der ThinkPHP-Anwendung zu und führen Sie sie aus.

Was ist besser, Laravel oder Thinkphp? Was ist besser, Laravel oder Thinkphp? Apr 09, 2024 pm 03:18 PM

Leistungsvergleich von Laravel- und ThinkPHP-Frameworks: ThinkPHP schneidet im Allgemeinen besser ab als Laravel und konzentriert sich auf Optimierung und Caching. Laravel schneidet gut ab, aber für komplexe Anwendungen ist ThinkPHP möglicherweise besser geeignet.

Entwicklungsvorschläge: So verwenden Sie das ThinkPHP-Framework zur Implementierung asynchroner Aufgaben Entwicklungsvorschläge: So verwenden Sie das ThinkPHP-Framework zur Implementierung asynchroner Aufgaben Nov 22, 2023 pm 12:01 PM

„Entwicklungsvorschläge: So verwenden Sie das ThinkPHP-Framework zur Implementierung asynchroner Aufgaben“ Mit der rasanten Entwicklung der Internettechnologie stellen Webanwendungen immer höhere Anforderungen an die Verarbeitung einer großen Anzahl gleichzeitiger Anforderungen und komplexer Geschäftslogik. Um die Systemleistung und das Benutzererlebnis zu verbessern, erwägen Entwickler häufig die Verwendung asynchroner Aufgaben, um einige zeitaufwändige Vorgänge auszuführen, z. B. das Senden von E-Mails, das Verarbeiten von Datei-Uploads, das Erstellen von Berichten usw. Im Bereich PHP bietet das ThinkPHP-Framework als beliebtes Entwicklungsframework einige praktische Möglichkeiten zur Implementierung asynchroner Aufgaben.

So installieren Sie thinkphp So installieren Sie thinkphp Apr 09, 2024 pm 05:42 PM

ThinkPHP-Installationsschritte: Bereiten Sie PHP-, Composer- und MySQL-Umgebungen vor. Erstellen Sie Projekte mit Composer. Installieren Sie das ThinkPHP-Framework und die Abhängigkeiten. Datenbankverbindung konfigurieren. Anwendungscode generieren. Starten Sie die Anwendung und besuchen Sie http://localhost:8000.

Wie ist die Leistung von thinkphp? Wie ist die Leistung von thinkphp? Apr 09, 2024 pm 05:24 PM

ThinkPHP ist ein leistungsstarkes PHP-Framework mit Vorteilen wie Caching-Mechanismus, Codeoptimierung, Parallelverarbeitung und Datenbankoptimierung. Offizielle Leistungstests zeigen, dass es mehr als 10.000 Anfragen pro Sekunde verarbeiten kann und in großen Websites und Unternehmenssystemen wie JD.com und Ctrip in praktischen Anwendungen weit verbreitet ist.

RPC-Dienst basierend auf ThinkPHP6 und Swoole zur Implementierung der Dateiübertragungsfunktion RPC-Dienst basierend auf ThinkPHP6 und Swoole zur Implementierung der Dateiübertragungsfunktion Oct 12, 2023 pm 12:06 PM

Der auf ThinkPHP6 und Swoole basierende RPC-Dienst implementiert die Dateiübertragungsfunktion. Einführung: Mit der Entwicklung des Internets ist die Dateiübertragung in unserer täglichen Arbeit immer wichtiger geworden. Um die Effizienz und Sicherheit der Dateiübertragung zu verbessern, wird in diesem Artikel die spezifische Implementierungsmethode der Dateiübertragungsfunktion basierend auf RPC-Diensten basierend auf ThinkPHP6 und Swoole vorgestellt. Wir werden ThinkPHP6 als Web-Framework verwenden und die RPC-Funktion von Swoole nutzen, um eine serverübergreifende Dateiübertragung zu erreichen. 1. Umweltstandard

See all articles