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.