CURD-Betrieb der Laravel-Framework-Datenbank und Verwendung kohärenter Operationen
Laravel-Framework-Datenbank-CURD-Operation, wie man die kohärente Operation verwendet
Laravel-Framework-Datenbank-CURD-Operation, wie man die kohärente Operation durchführt. Wir sind hier, um Ihnen ein entsprechendes Tutorial vorzustellen, insbesondere The Detaillierte Schritte werden unten vorgestellt.
Laravel ist ein einfaches und elegantes PHP-Webentwicklungs-Framework (PHP Web Framework). Es kann Sie von unordentlichen Codes wie Nudeln befreien; es kann Ihnen helfen, eine perfekte Netzwerk-APP zu erstellen, und jede Codezeile kann prägnant und ausdrucksstark sein.
1. Wählt
Alle Zeilen in der Tabelle abrufen
$users = DB::table('users')->get();
foreach ($users as $user)
{
var_dump($user->name);
}
Eine einzelne Zeile aus einer Tabelle abrufen
$user = DB::table('users')->where(' name' , 'John')->first();
var_dump($user->name);
Zeilen für eine einzelne Spalte abrufen
$name = DB::table('users' )-> ;where('name', 'John')->pluck('name');
Liste der Spaltenwerte abrufen
$roles = DB::table('roles')-> ;lists(' title');
Diese Methode gibt einen Array-Titel zurück. Sie können auch eine benutzerdefinierte Schlüsselspalte angeben, um das Array zurückzugeben.
$roles = DB::table('roles')->lists('title', 'name');
Geben Sie eine Auswahl an Klausel
$users = DB::table('users')->select('name', 'email')->get();
$users = DB::table('users' )->distinct()->get();
$users = DB::table('users')->select('name as user_name')->get();
Select-Klausel zu einer vorhandenen Abfrage hinzugefügt
$query = DB::table('users')->select('name');
$users = $query->addSelect( 'age')- >get();
where
$users = DB::table('users')->where('votes', '>', 100)->get ();
OR
$users = DB::table('users')->where('votes', '>', 100)->orWhere('name', 'John' )->get ();
Where Between
$users = DB::table('users')->whereBetween('votes', array(1, 100))-> 🎜>
Where Not Between
$users = DB::table('users')->whereNotBetween('votes', array(1, 100))->get() ;
Where In mit einem Array
$users = DB::table('users')->whereIn('id', array(1, 2, 3))->get( );
$users = DB::table('users')->whereNotIn('id', array(1, 2, 3))->get();
Verwenden von Where Null zum Suchen von Datensätzen mit Werte aufheben
$users = DB::table('users')->whereNull('updated_at')->get();
Sortieren nach, Gruppieren nach und Haben
$users = DB::table('users')->orderBy('name', 'desc')->groupBy('count')->having('count', '> ;', 100) ->get();
Offset & Limit
$users = DB::table('users')->skip(10)->take(5)-> 🎜>2. Verbindungen
Joins
Der Abfrage-Builder kann auch zum Schreiben von Verbindungsanweisungen verwendet werden. Schauen Sie sich das folgende Beispiel an:
DB::table('users')
->join('contacts', 'users.id', '=', 'contacts.user_id')
- >join('orders', 'users.id', '=', 'orders.user_id')
->select('users.id', 'contacts.phone', 'orders.price ')
->get();
Left-Join-Anweisung
DB::table('users')
->leftJoin('posts', 'users.id', '= ', 'posts.user_id')
->get();
DB::table('users')
->join('contacts', function($join)
{
$join->on('users.id', '=', 'contacts.user_id')->orOn(...);
})
->get( );
DB::table('users')
->join('contacts', function($join)
{
$join->on('users.id' , ' =', 'contacts.user_id')
->where('contacts.user_id', '>', 5);
})
->get();
3. Gruppierung
Manchmal müssen Sie möglicherweise erweiterte Where-Klauseln erstellen, z. B. „exists“ oder eine verschachtelte Parametergruppierung. Der Laravel-Abfrage-Builder kann Folgendes verarbeiten:
DB::table('users')
->where('name', '=', 'John')
->orWhere(function($ query)
{
$query->where('votes', '>', 100)
->where('title', '<>', 'Admin') ;
})
->get();
Die obige Abfrage erzeugt die folgende SQL:
wählen Sie * aus Benutzern aus, bei denen Name = 'John' oder (Stimmen > 100 und title
<> 'Admin')
Exists Statements
DB::table('users')
->whereExists(function($query)
{
$query->select(DB::raw(1))
->from('orders')
->whereRaw('orders.user_id = users.id');
} )
->get();
Die obige Abfrage erzeugt die folgende SQL:
wählen Sie * aus den Benutzern aus, in denen vorhanden ist (
wählen Sie 1 aus Bestellungen aus, bei denen Bestellungen.Benutzer_ID = Benutzer.ID
)
4. Aggregation
Der Abfrage-Builder bietet auch verschiedene Aggregationsmethoden, wie Statistiken, Max, Min, Durchschnitt und Summe.
$users = DB::table('users')->count();
$price = DB::table('orders')->max('price');
$price = DB::table('orders')->min('price');
$price = DB::table('orders')->avg('price');
$total = DB::table('users')->sum('votes');
Rohausdrücke
Manchmal müssen Sie möglicherweise eine Abfrage mit Rohausdrücken verwenden. Diese Ausdrücke werden in die Abfragezeichenfolge eingefügt. Achten Sie also darauf, keine SQL-Einfügungspunkte zu erstellen. Um einen Rohausdruck zu erstellen, können Sie DB:rawmethod:
Using A Raw Expression
$users = DB:: verwenden. table('users')
->select(DB::raw('count(*) as user_count, status'))
->where('status', '<>', 1)
->groupBy('status')
->get();
Wert einer Spalte erhöhen oder verringern
DB::table(' Benutzer')- >inkrementieren('Stimmen');
DB::table('Benutzer')->inkrementieren('Stimmen', 5);
DB::table('Benutzer')- >decrement( 'votes');
DB::table('users')->decrement('votes', 5);
Sie können auch zusätzliche Spaltenaktualisierungen angeben:
DB::table('users')->increment('votes', 1, array('name' => 'John'));
Einfügungen
Datensätze einfügen in die Tabelle
DB::table('users')->insert(
array('email' => 'john@example.com', 'votes' => 0)
) ;
Datensatz mit automatisch inkrementierender ID in Tabelle einfügen
Wenn die Tabelle ein automatisch inkrementierendes ID-Feld hat, verwenden Sie insertGetId, um einen Datensatz einzufügen und die ID abzurufen:
$id = DB::table('users')->insertGetId( array('email' => 'john@example.com', 'votes' => 0) );
Hinweis: Bei Verwendung der PostgreSQL-Methode insertGetId wird erwartet, dass die automatisch inkrementierende Spalte den Namen „id“ erhält.
Mehrere Datensätze in die Tabelle einfügen
Der Code lautet wie folgt:
DB::table('users')->insert(array(
array('email' => 'taylor @example.com', 'votes' => 0),
array('email' => 'dayle@example.com', 'votes' => 0),
));
4. Aktualisierungen
Datensätze in einer Tabelle aktualisieren
Der Code lautet wie folgt:
DB::table('users')
->where('id', 1 )
->update(array('votes' => 1));
5. Löscht
Datensätze in der Tabelle löschen
Der Code lautet wie folgt:
DB::table('users ')->where('votes', '<', 100)->delete();
Alle Datensätze in der Tabelle löschen
Der Code lautet wie folgt:
DB::table ('users')->delete();
Eine Tabelle löschen
Der Code lautet wie folgt:
DB::table ('users')->truncate();
6. Unions
Der Abfrage-Generator bietet auch eine schnelle Möglichkeit, zwei Abfragen zu „vereinigen“:
Der Code lautet wie folgt :
$first = DB::table( 'users')->whereNull('first_name');
$users =
DB::table('users')->whereNull(' last_name')->union($first)- >get();
Die Methode unionAll ist ebenfalls verfügbar und hat die gleiche Methodensignatur.
Pessimistisches Sperren
Der Abfrage-Generator enthält einige „pessimistische Sperren“-Funktionen, die Sie bei Ihren SELECT-Anweisungen unterstützen. Führen Sie die SELECT-Anweisung „Shared Lock“ aus. Sie können die Methode sharedLock zur Abfrage verwenden:
Der Code lautet wie folgt:
DB::table('users')->where('votes', '> ;',
100)->sharedLock()->get();
Aktualisieren Sie „lock“ in einer SELECT-Anweisung. Sie können die lockForUpdate-Methode verwenden, um Folgendes abzufragen:
Der Code lautet wie folgt:
DB ::table('users')->where('votes', '>', 100)->lockForUpdate()->get();
7. Abfrage zwischenspeichern
Sie können die Ergebnisse einer Abfrage mithilfe von Mnemoniken einfach zwischenspeichern:
Der Code lautet wie folgt:
$users = DB::table('users')-> erinnere(10)->get();
In diesem Beispiel werden die Ergebnisse der Abfrage zehn Minuten lang zwischengespeichert. Wenn Abfrageergebnisse zwischengespeichert werden, werden sie nicht in der Datenbank ausgeführt und die Ergebnisse werden aus dem von Ihrer Anwendung angegebenen Standard-Cache-Treiber geladen. Wenn Sie einen Treiber verwenden, der Caching unterstützt, können Sie dem Cache auch Tags hinzufügen:
Der Code lautet wie folgt:
$users = DB::table('users')-> ;cacheTags(array ('people', 'authors'))->remember(10)->get();

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Methode zum Abholen des Rücksendecode, wenn das Senden von Laravel -E -Mails fehlschlägt. Wenn Sie Laravel zur Entwicklung von Anwendungen verwenden, stellen Sie häufig Situationen auf, in denen Sie Überprüfungscodes senden müssen. Und in Wirklichkeit ...

Laravel -Zeitplan -Aufgabe Ausführen nicht reagierende Fehlerbehebung Bei Verwendung der Zeitplanung von Laravel -Zeitplänen werden viele Entwickler auf dieses Problem stoßen: Zeitplan: Run ...

Die Methode zum Umgang mit Laravels E -Mail -Versagen zum Senden von Verifizierungscode besteht darin, Laravel zu verwenden ...

So implementieren Sie die Tabellenfunktion von benutzerdefiniertem Klicken, um Daten in dcatadmin (laravel-admin) hinzuzufügen, wenn Sie DCAT verwenden ...

Die Auswirkungen des Austauschs von Redis -Verbindungen im Laravel -Framework und der Auswahl von Methoden bei Verwendung von Laravel -Framework und Redis können Entwickler auf ein Problem stoßen: Durch Konfiguration ...

Benutzerdefinierte Mieterdatenbankverbindung in Laravel Multi-Tenant-Erweiterungspaket Stanz/Mietverhältnis beim Erstellen von Multi-Mandanten-Anwendungen mit Laravel Multi-Tenant-Erweiterungspaket Stanz/Mietverhältnis, ...

Laraveleloquent-Modellab Abruf: Das Erhalten von Datenbankdaten Eloquentorm bietet eine prägnante und leicht verständliche Möglichkeit, die Datenbank zu bedienen. In diesem Artikel werden verschiedene eloquente Modellsuchtechniken im Detail eingeführt, um Daten aus der Datenbank effizient zu erhalten. 1. Holen Sie sich alle Aufzeichnungen. Verwenden Sie die Methode All (), um alle Datensätze in der Datenbanktabelle zu erhalten: UseApp \ Models \ post; $ posts = post :: all (); Dies wird eine Sammlung zurückgeben. Sie können mit der Foreach-Schleife oder anderen Sammelmethoden auf Daten zugreifen: foreach ($ postas $ post) {echo $ post->

Verarbeiten Sie 7 Millionen Aufzeichnungen effizient und erstellen Sie interaktive Karten mit Geospatial -Technologie. In diesem Artikel wird untersucht, wie über 7 Millionen Datensätze mithilfe von Laravel und MySQL effizient verarbeitet und in interaktive Kartenvisualisierungen umgewandelt werden können. Erstes Herausforderungsprojektanforderungen: Mit 7 Millionen Datensätzen in der MySQL -Datenbank wertvolle Erkenntnisse extrahieren. Viele Menschen erwägen zunächst Programmiersprachen, aber ignorieren die Datenbank selbst: Kann sie den Anforderungen erfüllen? Ist Datenmigration oder strukturelle Anpassung erforderlich? Kann MySQL einer so großen Datenbelastung standhalten? Voranalyse: Schlüsselfilter und Eigenschaften müssen identifiziert werden. Nach der Analyse wurde festgestellt, dass nur wenige Attribute mit der Lösung zusammenhängen. Wir haben die Machbarkeit des Filters überprüft und einige Einschränkungen festgelegt, um die Suche zu optimieren. Kartensuche basierend auf der Stadt
