Heim >PHP-Framework >Laravel >So beurteilen Sie Abfrageergebnisse in Laravel

So beurteilen Sie Abfrageergebnisse in Laravel

PHPz
PHPzOriginal
2023-04-23 09:12:131146Durchsuche

In Laravel-Anwendungen müssen wir normalerweise die Datenbank abfragen, um die erforderlichen Daten zu erhalten. Während dieser Abfragen müssen wir manchmal bedingte Anweisungen in den Code schreiben, um die Abfrageergebnisse zu überprüfen und auf der Grundlage der Ergebnisse geeignete Maßnahmen zu ergreifen. Daher wird in diesem Artikel erläutert, wie man Abfrageergebnisse beurteilt und bedingte Anweisungen in Laravel schreibt.

Zuerst müssen wir die von Laravel-Abfragen zurückgegebenen Ergebnistypen verstehen. Abfragen in Laravel geben unterschiedliche Ergebnistypen zurück, je nachdem, welche Methode Sie beim Ausführen der Abfrage verwenden. Im Folgenden sind einige der am häufigsten verwendeten Abfragemethoden und ihre Rückgabewerttypen aufgeführt:

  1. get() – gibt eine Sammlung von Abfrageergebnissen zurück (Collection)
  2. first() – gibt eine einzelne Modellinstanz (Model) zurück
  3. find () – basierend auf der ID. Finde eine einzelne Modellinstanz (Model)
  4. pluck() – Gibt ein einzelnes Spaltenarray zurück (Array)
  5. count() – Gibt einen ganzzahligen Wert (Int) zurück
  6. exists() – Gibt einen Booleschen Wert zurück value (Boolean)

Connect Als nächstes lernen wir, wie man diese Ergebnistypen ermittelt und bedingte Anweisungen schreibt.

  1. Collection

Collection ist einer der am häufigsten verwendeten Ergebnistypen in Laravel. Wenn wir mit der Methode get() abfragen, wird eine Collection-Instanz zurückgegeben.

Um festzustellen, ob die Sammlung leer ist, verwenden Sie die Methode isEmpty(). Beispiel:

$users = DB::table('users')->get();

if ($users->isEmpty()) {
    // Collection为空的情况下执行的代码
} else {
    // Collection不为空的情况下执行的代码
}

Wenn Sie Code nur ausführen müssen, wenn nur ein Datensatz in der Sammlung vorhanden ist, verwenden Sie die Methode isNotEmpty(). Zum Beispiel:

$users = DB::table('users')->get();

if ($users->isNotEmpty()) {
    // Collection中有记录的情况下执行的代码
} else {
     // Collection为空的情况下执行的代码
}

Wenn Sie einen bestimmten Datensatz in der Sammlung finden müssen, verwenden Sie die Methode contains(). Zum Beispiel:

$users = DB::table('users')->get();

if ($users->contains('name', 'John')) {
    // Collection中包含记录的情况下执行的代码
} else {
    // Collection中不包含记录的情况下执行的代码
}
  1. Model

Wenn wir die Methode first() zur Abfrage verwenden, wird eine Model-Instanz zurückgegeben. In diesem Fall können wir eine if-Anweisung verwenden, um festzustellen, ob das Ergebnis leer ist. Beispiel:

$user = DB::table('users')->where('email', 'john@example.com')->first();

if ($user) {
    // Model实例存在的情况下执行的代码
} else {
    // Model实例不存在的情况下执行的代码
}

Wenn Sie zum Suchen eines Datensatzes die Methode find() verwenden, können Sie mit einer if-Anweisung feststellen, ob das Ergebnis leer ist. Zum Beispiel:

$user = DB::table('users')->find(1);

if ($user) {
    // Model实例存在的情况下执行的代码
} else {
    // Model实例不存在的情况下执行的代码
}
  1. Array

Wenn Sie die pluck()-Methode verwenden, um eine einzelne Spalte in einer Abfrage abzurufen, wird ein Array zurückgegeben. In diesem Fall können wir die Funktion empty() verwenden, um zu prüfen, ob das Array leer ist. Zum Beispiel:

$emails = DB::table('users')->pluck('email');

if (empty($emails)) {
    // 数组为空的情况下执行的代码
} else {
    // 数组不为空的情况下执行的代码
}
  1. Int

Wenn Sie die Methode count() verwenden, um die Anzahl der Abfrageergebnisse abzurufen, wird ein ganzzahliger Wert zurückgegeben. In diesem Fall können wir die if-Anweisung verwenden, um zu prüfen, ob das Ergebnis 0 ist. Zum Beispiel:

$count = DB::table('users')->count();

if ($count == 0) {
    // 记录数为0的情况下执行的代码
} else {
    // 记录数不为0的情况下执行的代码
}
  1. Boolean

Wenn wir die Methode exist() verwenden, um zu prüfen, ob ein Datensatz vorhanden ist, wird ein boolescher Wert zurückgegeben. Zum Beispiel:

if (DB::table('users')->where('name', 'John')->exists()) {
    // 存在记录的情况下执行的代码
} else {
    // 不存在记录的情况下执行的代码
}

Summary

In Laravel-Anwendungen müssen wir normalerweise bedingte Anweisungen basierend auf unterschiedlichen Abfrageergebnissen schreiben. In diesem Artikel wird erläutert, wie Abfrageergebnisse der Typen „Collection“, „Model“, „Array“, „Int“ und „Boolean“ beurteilt werden, und es wird der entsprechende Beispielcode bereitgestellt. Durch diese Beispiele können wir Laravel-Abfragemethoden flexibler nutzen und verschiedene Situationen bewältigen.

Das obige ist der detaillierte Inhalt vonSo beurteilen Sie Abfrageergebnisse in Laravel. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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