Zend Framework - Model & Database

Pada bab ini, kita akan membahas tentang berbagai model dan database Zend Framework.

Model dalam Zend Framework

Model mendefinisikan representasi data logis dari aplikasi. Misalnya, dalam aplikasi keranjang belanja - Produk, Pelanggan, Keranjang, dan Pesanan adalah model. Mereka menentukan properti entitas yang dimilikinya. Beberapa konsep model adalah sebagai berikut -

  • Pengontrol berkomunikasi dengan model dan meminta mereka untuk mengambil informasi yang mereka butuhkan. Informasi yang diambil ini kemudian diteruskan oleh pengontrol ke View. Terakhir, View akan membuat model sebagai data presentasi yang dapat dikonsumsi pengguna.

  • Sangat jarang model berinteraksi langsung dengan tampilan, tetapi terkadang hal itu dapat terjadi.

  • Model dapat berbicara satu sama lain dan tidak mandiri. Mereka memiliki hubungan satu sama lain. Hubungan ini mempermudah dan mempercepat pengontrol untuk mendapatkan informasi, karena tidak harus berinteraksi dengan model yang berbeda; model dapat melakukannya sendiri.

Mari kita lihat model sederhana - MyModel

<?php  
namespace Tutorial\Model;  
class Book { 
   public $id; public $author; 
   public $title; 
}

Database dalam Zend Framework

Zend framework menyediakan kelas sederhana dan kaya fitur, Zend \ Db \ TableGateway \ TableGateway untuk menemukan, menyisipkan, memperbarui, dan menghapus data dari tabel database.

Mari kita lihat bagaimana menghubungkan MySqlservice melalui driver PDO PHP dalam kerangka Zend melalui langkah-langkah berikut.

Langkah 1: Buat database di MySQL

Buat database tutorialsdi server MySQL lokal. Kita bisa gunakanphpmyadminatau alat GUI MySQL lainnya untuk tujuan ini. Mari kita gunakanMySQL clientdi command prompt. Sambungkan ke server mysql dan jalankan perintah berikut untuk membuat filetutorial database.

create database tutorials

Langkah 2: Buat tabel di tutorial db

Sekarang mari kita buat database book dalam tutorials db menggunakan perintah SQL berikut.

use tutorials;  
CREATE TABLE book ( 
   id int(11) NOT NULL auto_increment, 
   author varchar(100) NOT NULL, 
   title varchar(100) NOT NULL, 
   PRIMARY KEY (id) 
);

Langkah 3: Isi data di tabel buku

Isi booktabel dengan data sampel. Gunakan perintah SQL berikut.

INSERT INTO book (author, title) VALUES ('Dennis Ritchie', 'C Programming'); 
INSERT INTO book (author, title) VALUES ('James gosling', 'Java Programming'); 
INSERT INTO book (author, title) VALUES ('Rasmus Lerdorf', 'Programming PHP');

Langkah 4: Perbarui Koneksi Database

Perbarui file konfigurasi global, yaitu - myapp / config / autoload / global.php dengan informasi drive database yang diperlukan.

<?php 
return array( 
   'db' => array( 
      'driver' => 'Pdo', 
      'dsn' => 'mysql:dbname = tutorials;host = localhost', 
      'driver_options' => array( 
         PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES \'UTF8\'' 
      ), 
   ), 
   'service_manager' => array( 
      'factories' => array(  
         'Zend\Db\Adapter\Adapter' => 'Zend\Db\Adapter\AdapterServiceFactory', 
      ), 
   ), 
);

Langkah 5: Perbarui Kredensial Database

Perbarui kredensial database di file konfigurasi lokal, yaitu - myapp / config / autoload / local.php. Dengan cara ini, kita dapat memisahkan kredensial koneksi database lokal dan langsung.

<?php 
return array( 
   'db' => array( 
      'username' => '<user_name>', 
      'password' => '<password>', 
   ), 
);

Langkah 6: Buat Model untuk Buku

Mari kita buat Model, Book dalam modul kami srcdirektori. Umumnya, model dikelompokkan dalam folder Model - /myapp/module/Tutorial/src/Model/Book.php.

<?php  
namespace Tutorial\Model;  
class Book { 
   public $id; 
   public $author; public $title; 
}

Langkah 7: Terapkan exchangeArray dalam model buku

Itu TableGateway berinteraksi dengan model melalui exchangeArrayfungsi. Argumen standar dari fungsi exchangeArray adalah kumpulan hasil database yang disimpan sebagai array PHP. MenggunakanexchangeArrayfunction, properti model dapat dengan mudah disinkronkan dengan tabel database terkait.

Perbarui model, Book seperti yang ditunjukkan di bawah ini -

<?php  
namespace Tutorial\Model;  
class Book { 
   public $id; public $author; 
   public $title; public function exchangeArray($data) { 
      $this->id = (!empty($data['id'])) ? $data['id'] : null; $this->Author = (!empty($data['author'])) ? $data['author'] : null; 
      $this->Title = (!empty($data['title'])) ? $data['title'] : null; 
   } 
}

Langkah 8: Gunakan TableGateway untuk mengambil buku

Buat kelas, BookTableuntuk mengambil informasi buku dari database. Buat kelas, BookTable diModel folder itu sendiri.

<?php  
namespace Tutorial\Model;  
use Zend\Db\TableGateway\TableGatewayInterface;  
class BookTable {
   protected $tableGateway; 
   public function __construct(TableGatewayInterface $tableGateway) { $this->tableGateway = $tableGateway; } public function fetchAll() { $resultSet = $this->tableGateway->select(); return $resultSet; 
   } 
}

Kami telah menggunakan select()metode kelas TableGateway untuk mengambil informasi buku dari database. Tapi, kami belum menggunakan referensi apa pun ke tabel -bookdi dalam kode. TableGateway bersifat generik dan dapat mengambil data dari tabel mana pun dengan menggunakan konfigurasi tertentu. Biasanya, konfigurasi ini dilakukan di filemodule.config.php file, yang akan kita bahas pada langkah selanjutnya.

Langkah 9: Konfigurasi kelas BookTable

Perbarui modul tutorial, Module.php dengan getServiceConfig() metode.

<?php
namespace Tutorial;
use Zend\Db\Adapter\AdapterInterface;
use Zend\Db\ResultSet\ResultSet;
use Zend\Db\TableGateway\TableGateway;
use Zend\ModuleManager\Feature\ConfigProviderInterface;

class Module implements ConfigProviderInterface {
   
   public function getConfig() {
      return include __DIR__ . '/../config/module.config.php';
   }
   public function getServiceConfig() {
      return [
         'factories' => [
            Model\BookTable::class => function ($container) { $tableGateway = $container->get(Model\BookTableGateway::class); $table = new Model\BookTable($tableGateway); return $table;
            },
            Model\BookTableGateway::class => function ($container) { $dbAdapter = $container->get(AdapterInterface::class); $resultSetPrototype = new ResultSet();
               $resultSetPrototype->setArrayObjectPrototype(new Model\Book()); return new TableGateway('book', $dbAdapter, null, $resultSetPrototype);
            },
         ],
      ];
   }
}

Di sini, kami telah mendaftarkan BookTablekelas menggunakan manajer layanan. Kelas BookTable digunakan untuk mengambil informasi buku dan dengan mendaftarkannya, kita dapat mengaksesnya dimanapun dibutuhkan. Karena, layanan terdaftar dibagikan, mereka meningkatkan kinerja, mengurangi konsumsi memori, dll.

Item lain, Model \ BookTableGateway :: class adalah objek TableGateway yang dikhususkan untuk file Book model dan merupakan ketergantungan dari BookTable.

Langkah 10: Perbarui Konfigurasi TutorialController

Kami membutuhkan BookTablelayanan di pengontrol tutorial untuk mengambil informasi buku. Untuk mendapatkan layanan BookTable, daftarkan sebagai dependensi konstruktor di TutorialController.

Ketergantungan Pembuat ini membantu mendapatkan layanan BookTable sementara pengontrol itu sendiri dalam tahap inisialisasi. Perbarui bagian pengontrol dari konfigurasi modul tutorial,module.config.php seperti gambar dibawah.

'controllers' => [ 
   'factories' => [ 
      Controller\TutorialController::class => function($container) { 
         return new Controller\TutorialController( 
            $container->get(Model\BookTable::class) 
         ); 
      }, 
   ], 
],

Langkah 11: Perbarui Pengontrol Tutorial

Ini dilakukan dengan mengikuti tiga langkah berikut.

  • Tambahkan konstruktor dengan BookTable sebagai argumen.
private $table;
public function __construct(BookTable $table) { $this->table = $table; 
}
  • Ambil informasi buku menggunakan BookTable's fetchAll() metode dan mendaftarkannya ke tampilan.

public function indexAction() { 
   $view = new ViewModel([ 
      'data' => $this->table->fetchAll(), ]); return $view; 
}
  • Tampilkan informasi buku dalam skrip view.

<table class = "table"> 
   <tr> 
      <th>Author</th> 
      <th>Title</th> 
      <th> </th> 
   </tr> 
   <?php foreach ($data as $sampledata) : ?> 
   <tr> 
      <td><?php echo $this->escapeHtml($data->author);?></td>  
      <td><?php echo $this->escapeHtml($data->title);?></td> 
   </tr> 
   <?php endforeach ?> 
</table>

Langkah 12: Jalankan aplikasi

Periksa aplikasi dengan menjalankan - http://localhost:8080/tutorial.