Yii - Datenanbieter

Yii bietet eine Reihe von Datenproviderklassen, die Paginierung und Sortierung kapseln. Ein Datenprovider implementiert yii \ data \ DataProviderInterface. Es unterstützt das Abrufen sortierter und paginierter Daten. Datenanbieter arbeiten normalerweise mit Daten-Widgets.

Yii beinhaltet -

  • ActiveDataProvider - Verwendet yii\db\ActiveQuery oder yii\db\Query Daten aus Datenbanken abfragen.

  • SqlDataProvider - Führt SQL aus und gibt Daten als Arrays zurück.

  • ArrayDataProvider - Nimmt ein großes Array und gibt ein Stück davon zurück.

Sie definieren das Sortier- und Paginierungsverhalten eines Datenanbieters, indem Sie dessen konfigurieren pagination und sortEigenschaften. Daten-Widgets wie zyii\grid\GridView, haben eine Eigenschaft namens dataProviderDies nimmt eine Datenproviderinstanz und zeigt die Daten auf dem Bildschirm an.

DB vorbereiten

Step 1- Erstellen Sie eine neue Datenbank. Die Datenbank kann auf zwei Arten vorbereitet werden.

  • Führen Sie im Terminal mysql -u root –p aus .

  • Erstellen Sie eine neue Datenbank über CREATE DATABASE helloworld CHARACTER SET utf8 COLLATE utf8_general_ci;

Step 2 - Konfigurieren Sie die Datenbankverbindung in der config/db.phpDatei. Die folgende Konfiguration gilt für das derzeit verwendete System.

<?php
   return [
      'class' => 'yii\db\Connection',
      'dsn' => 'mysql:host = localhost;dbname = helloworld',
      'username' => 'vladimir',
      'password' => '12345',
      'charset' => 'utf8',
   ];
?>

Step 3 - Im Stammordner run ./yii migrate/create test_table. Dieser Befehl erstellt eine Datenbankmigration zur Verwaltung unserer Datenbank. Die Migrationsdatei sollte in der angezeigt werdenmigrations Ordner des Projektstamms.

Step 4 - Ändern Sie die Migrationsdatei (m160106_163154_test_table.php in diesem Fall) auf diese Weise.

<?php
   use yii\db\Schema;
   use yii\db\Migration;
   class m160106_163154_test_table extends Migration {
      public function safeUp() {
         $this->createTable("user", [
            "id" => Schema::TYPE_PK,
            "name" => Schema::TYPE_STRING,
            "email" => Schema::TYPE_STRING,
         ]);
         $this->batchInsert("user", ["name", "email"], [
            ["User1", "[email protected]"],
            ["User2", "[email protected]"],
            ["User3", "[email protected]"],
            ["User4", "[email protected]"],
            ["User5", "[email protected]"],
            ["User6", "[email protected]"],
            ["User7", "[email protected]"],
            ["User8", "[email protected]"],
            ["User9", "[email protected]"],
            ["User10", "[email protected]"],
            ["User11", "[email protected]"],
         ]);
      }
      public function safeDown() {
         $this->dropTable('user');
      }
   }
?>

Die obige Migration erstellt eine userTabelle mit diesen Feldern: ID, Name und E-Mail. Es werden auch einige Demo-Benutzer hinzugefügt.

Step 5 - Im Projektstamm run ./yii migrate um die Migration auf die Datenbank anzuwenden.

Step 6 - Jetzt müssen wir ein Modell für unsere erstellen userTabelle. Der Einfachheit halber werden wir das verwendenGiiTool zur Codegenerierung. Öffne dasurl: http://localhost:8080/index.php?r=gii. Klicken Sie dann auf die Schaltfläche "Start" unter der Überschrift "Modellgenerator". Geben Sie den Tabellennamen ("Benutzer") und die Modellklasse ("MyUser") ein, klicken Sie auf die Schaltfläche "Vorschau" und schließlich auf die Schaltfläche "Generieren".

Das MyUser-Modell sollte im Modellverzeichnis angezeigt werden.

Aktiver Datenanbieter

Step 1 - Erstellen Sie eine Funktion namens actionDataProvider in der SiteController.

public function actionDataProvider(){
   $query = MyUser::find();
   $provider = new ActiveDataProvider([
      'query' => $query,
      'pagination' => [
         'pageSize' => 2,
      ],
   ]);
   // returns an array of users objects
   $users = $provider->getModels();
   var_dump($users);
}

Im obigen Code definieren wir eine Instanz von ActiveDataProviderKlasse und Anzeige Benutzer von der ersten Seite. Dasyii\data\ActiveDataProvider Klasse verwendet die DB-Anwendungskomponente als DB-Verbindung.

Step 2 - Wenn Sie die lokale Hostadresse eingeben http://localhost:8080/index.php?r=site/dataprovidersehen Sie die folgende Ausgabe.

SQL-Datenprovider

Das yii\data\SqlDataProvider Klasse arbeitet mit rohen SQL-Anweisungen.

Step 1 - Ändern Sie die actionDataProvider Methode auf diese Weise.

public function actionDataProvider() {
   $count = Yii::$app->db->createCommand('SELECT COUNT(*) FROM user')->queryScalar();
   $provider = new SqlDataProvider([
      'sql' => 'SELECT * FROM user',
      'totalCount' => $count,
      'pagination' => [
         'pageSize' => 5,
      ],
      'sort' => [
         'attributes' => [
            'id',
            'name',
            'email',
         ],
      ],
   ]);
   // returns an array of data rows
   $users = $provider->getModels();
   var_dump($users);
}

Step 2 - Typ http://localhost:8080/index.php?r=site/data-provider In der Adressleiste des Webbrowsers sehen Sie die folgende Ausgabe.

Array-Datenprovider

Das yii\data\ArrayDataProviderKlasse ist am besten für die Arbeit mit großen Arrays. Elemente in diesem Array können entweder Abfrageergebnisse von DAO- oder Active Record-Instanzen sein.

Step 1 - Ändern Sie die actionDataProvider Methode auf diese Weise.

public function actionDataProvider() {
   $data = MyUser::find()->asArray()->all();
   $provider = new ArrayDataProvider([
      'allModels' => $data,
      'pagination' => [
         'pageSize' => 3,
      ],
      'sort' => [
         'attributes' => ['id', 'name'],
      ],
   ]);
   // get the rows in the currently requested page
   $users = $provider->getModels();
   var_dump($users);
}

Step 2 - Wenn Sie zur Adresse gehen http://localhost:8080/index.php?r=site/data-provider Über den Webbrowser sehen Sie die folgende Ausgabe.

Beachten Sie, dass der Array Data Provider im Gegensatz zu SQL Data Provider und Active Data Provider alle Daten in den Speicher lädt, sodass er weniger effizient ist.