Yii - Abfrage-Generator

Mit dem Abfrage-Generator können Sie SQL-Abfragen programmgesteuert erstellen. Mit dem Abfrage-Generator können Sie besser lesbaren SQL-Code schreiben.

Um den Abfrage-Generator zu verwenden, sollten Sie die folgenden Schritte ausführen:

  • Erstellen Sie ein yii \ db \ Query-Objekt.
  • Führen Sie eine Abfragemethode aus.

Einen bauen yii\db\Query Objekt sollten Sie verschiedene Query Builder-Funktionen aufrufen, um verschiedene Teile einer SQL-Abfrage zu definieren.

Step 1 - Um eine typische Verwendung des Abfrage-Generators anzuzeigen, ändern Sie die actionTestDb Methode auf diese Weise.

public function actionTestDb() {
   //generates "SELECT id, name, email FROM user WHERE name = 'User10';"
   $user = (new \yii\db\Query())
      ->select(['id', 'name', 'email'])
      ->from('user')
      ->where(['name' => 'User10'])
      ->one();
   var_dump($user);
}

Step 2 - Geh zu http://localhost:8080/index.php?r=site/test-dbsehen Sie die folgende Ausgabe.

Where () Funktion

Das where()Funktion definiert das WHERE-Fragment einer Abfrage. So geben Sie an: aWHERE Bedingung können Sie drei Formate verwenden.

  • string format - 'name = User10'

  • hash format - ['name' => 'User10', 'email => [email protected]']

  • operator format - ['like', 'name', 'user']

Beispiel für ein String-Format

public function actionTestDb() {
   $user = (new \yii\db\Query())
      ->select(['id', 'name', 'email'])
      ->from('user')
      ->where('name = :name', [':name' => 'User11'])
      ->one();
   var_dump($user);
}

Es folgt die Ausgabe.

Beispiel für ein Hash-Format

public function actionTestDb() {
   $user = (new \yii\db\Query())
      ->select(['id', 'name', 'email'])
      ->from('user')
      ->where([
         'name' => 'User5',
         'email' => '[email protected]'
      ])
      ->one();
   var_dump($user);
}

Es folgt die Ausgabe.

Mit dem Operatorformat können Sie beliebige Bedingungen im folgenden Format definieren:

[operator, operand1, operand2]

Der Bediener kann -

  • and - ['und', 'id = 1', 'id = 2'] erzeugen id = 1 UND id = 2 oder: ähnlich dem Operator und

  • between - ['zwischen', 'id', 1, 15] generiert die ID ZWISCHEN 1 UND 15

  • not between - ähnlich dem Zwischenoperator, aber ZWISCHEN wird durch NICHT ZWISCHEN ersetzt

  • in - ['in', 'id', [5,10,15]] generiert die ID IN (5,10,15)

  • not in - Ähnlich wie beim In-Operator, jedoch wird IN durch NOT IN ersetzt

  • like - ['like', 'name', 'user'] generiert den Namen LIKE '% user%'

  • or like - ähnlich dem ähnlichen Operator, aber OR wird verwendet, um die LIKE-Prädikate zu teilen

  • not like - ähnlich dem ähnlichen Operator, aber LIKE wird durch NOT LIKE ersetzt

  • or not like - Ähnlich dem nicht ähnlichen Operator, aber OR wird verwendet, um die NOT LIKE-Prädikate zu verketten

  • exists - erfordert einen Operanden, der eine Instanz der Klasse yii \ db \ Query sein muss

  • not exists - ähnelt dem existierenden Operator, erstellt jedoch einen NOT EXISTS-Ausdruck (Unterabfrage)

  • <, <=, >, >=, oder ein anderer DB-Operator: ['<', 'id', 10] generiert die ID <10

Beispiel für das Operatorformat

public function actionTestDb() {
   $users = (new \yii\db\Query())
      ->select(['id', 'name', 'email'])
      ->from('user')
      ->where(['between', 'id', 5, 7])
      ->all();
   var_dump($users);
}

Es folgt die Ausgabe.

OrderBy () Funktion

Das orderBy() Funktion definiert das ORDER BY-Fragment.

Example - -

public function actionTestDb() {
   $users = (new \yii\db\Query())
      ->select(['id', 'name', 'email'])
      ->from('user')
      ->orderBy('name DESC')
      ->all();
   var_dump($users);
}

Es folgt die Ausgabe.

groupBy () Funktion

Das groupBy() Funktion definiert das GROUP BY-Fragment, während die having() Methode gibt das HAVING-Fragment an.

Example - -

public function actionTestDb() {
   $users = (new \yii\db\Query())
      ->select(['id', 'name', 'email'])
      ->from('user')
      ->groupBy('name')
      ->having('id < 5')
      ->all();
   var_dump($users);
}

Es folgt die Ausgabe.

Das limit() und offset() Methoden definiert die LIMIT und OFFSET Fragmente.

Example - -

public function actionTestDb() {
   $users = (new \yii\db\Query())
      ->select(['id', 'name', 'email'])
      ->from('user')
      ->limit(5)
      ->offset(5)
      ->all();
   var_dump($users);
}

Sie können die folgende Ausgabe sehen -

Das yii\db\Query Klasse bietet eine Reihe von Methoden für verschiedene Zwecke -

  • all() - Gibt ein Array von Zeilen mit Name-Wert-Paaren zurück.

  • one() - Gibt die erste Zeile zurück.

  • column() - Gibt die erste Spalte zurück.

  • scalar() - Gibt einen Skalarwert aus der ersten Zeile und der ersten Spalte des Ergebnisses zurück.

  • exists() - Gibt einen Wert zurück, der angibt, ob die Abfrage ein Ergebnis enthält

  • count() Gibt das Ergebnis einer COUNT-Abfrage zurück

  • other aggregation query methods- Beinhaltet Summe ($ q), Durchschnitt ($ q), Maximum ($ q), Min ($ q). Der Parameter $ q kann entweder ein Spaltenname oder ein DB-Ausdruck sein.