Corak repositori pertama kali diperkenalkan oleh Eric Evans dalam buku Reka Bentuk Dipacu Domainnya. Malah, repositori adalah titik masuk untuk aplikasiuntuk mengakses lapisan domain.
Ringkasnya, repositori membenarkan semua kod anda menggunakan objek tanpa mengetahui cara objek itu diteruskan. Repositori mengandungi semua pengetahuan tentang ketekunan, termasuk pemetaan dari jadual ke objek. Ini memberikan pandangan yang lebih berorientasikan objek pada lapisan kegigihan dan menjadikan kod pemetaan lebih terkapsul.
Satu-satunya cara untuk membolehkan repositori anda berfungsi dalam Laravel (sebagai repositori sebenar - buku Reka Bentuk Dipacu Domain Eric Evans) ialah menukar ORM lalai daripada Rekod Aktif kepada Pemeta Data. Pengganti terbaik adalah doktrin.
Doctrine ialah ORM (Object Relational Mapping) yang melaksanakan corak Pemeta Data dan membolehkan anda mengasingkan sepenuhnya peraturan perniagaan aplikasi anda daripada lapisan kegigihan pangkalan data. Doktrin menggunakan DQL, bukan SQL. DQL membawakan anda Bahasa Pertanyaan Objek, yang bermaksud anda akan membuat pertanyaan menggunakan istilah objek dan bukannya istilah pertanyaan hubungan tradisional.
Ia membolehkan anda menulis pertanyaan pangkalan data dalam cara berorientasikan objek dan membantu apabila anda perlu membuat pertanyaan pangkalan data dengan cara yang tidak mungkin menggunakan kaedah repositori lalai. Pada pendapat saya, DQL adalah cara yang paling berkuasa untuk terus berhubung dengan pangkalan data.
Entiti Doktrin hanyalah kelas mudah PHP biasa yang tidak menambah sebarang overhed warisan ORM. Doktrin menggunakan warisan yang sama untuk mengurus berbilang permintaan pertanyaan tanpa mengakses pangkalan data, yang bermaksud objek entiti hadir sepanjang permintaan.
Satu lagi ciri bagus Doktrin ialah bukannya memindahkan fail untuk mencipta skema pangkalan data, pangkalan data dibuat secara automatik untuk mencerminkan metadata dalam anotasi entiti. Fasih, sebaliknya, kurang kompleks dan sangat mudah digunakan.
Perbandingan lengkap antara kedua-dua ini memerlukan artikel berasingan. Seperti yang anda lihat, objek Doktrin lebih ringan dan lebih abstrak. Walau bagaimanapun, Doktrin hanya sesuai untuk projek tertentu, jadi kadangkala ia boleh membuat overhed untuk anda. Saya percaya terpulang kepada pengaturcara untuk memilih ORM terbaik untuk aplikasi.
Kini tiba masanya untuk mencipta aplikasi blog menggunakan Laravel. Pertama, kita perlu menubuhkan doktrin. Terdapat jambatan untuk memadankan konfigurasi sedia ada Laravel 5. Untuk memasang Doktrin 2 dalam projek Laravel, kami menjalankan arahan berikut:
composer require laravel-doctrine/orm
Seperti biasa, pakej ini harus ditambahkan pada app/config.php
sebagai penyedia perkhidmatan: app/config.php
,作为服务提供者:
LaravelDoctrine\ORM\DoctrineServiceProvider::class,
还应该配置别名:
'EntityManager' => LaravelDoctrine\ORM\Facades\EntityManager::class
最后,我们发布包配置:
php artisan vendor:publish --tag="config"
现在我们已经完成了。
实体是应用程序 AppEntitiesPost.php
的重要组成部分:
namespace App\Entity; use Doctrine\ORM\Mapping as ORM; /** * @ORM\Entity * @ORM\Table(name="posts") * @ORM\HasLifecycleCallbacks() */ class Post { /** * @var integer $id * @ORM\Column(name="id", type="integer", unique=true, nullable=false) * @ORM\Id * @ORM\GeneratedValue(strategy="AUTO") * */ private $id; /** * @ORM\Column(type="string") */ private $title; /** * @ORM\Column(type="text") */ private $body; public function __construct($input) { $this->setTitle($input['title']); $this->setBody($input['body']); } public function setId($id) { return $this->id=$id; } public function getId() { return $this->id; } public function getTitle() { return $this->title; } public function setTitle($title) { $this->title = $title; } public function getBody() { return $this->body; } public function setBody($body) { $this->body = $body; } }
现在是时候创建存储库了,这在前面已经描述过了。 App/Repositories/PostRepo.php
:
namespace App\Repository; use App\Entity\Post; use Doctrine\ORM\EntityManager; class PostRepo { /** * @var string */ private $class = 'App\Entity\Post'; /** * @var EntityManager */ private $em; public function __construct(EntityManager $em) { $this->em = $em; } public function create(Post $post) { $this->em->persist($post); $this->em->flush(); } public function update(Post $post, $data) { $post->setTitle($data['title']); $post->setBody($data['body']); $this->em->persist($post); $this->em->flush(); } public function PostOfId($id) { return $this->em->getRepository($this->class)->findOneBy([ 'id' => $id ]); } public function delete(Post $post) { $this->em->remove($post); $this->em->flush(); } /** * create Post * @return Post */ private function perpareData($data) { return new Post($data); } }
控制器:App/Http/Controllers/PostController.php
:
namespace App\Http\Controllers; use App\Repository\PostRepo as repo; use App\Validation\PostValidator; class PostController extends Controller { private $repo; public function __construct(repo $repo) { $this->repo = $repo; } public function edit($id=NULL) { return View('admin.edit')->with(['data' => $this->repo->postOfId($id)]); } public function editPost() { $all = Input::all(); $validate = PostValidator::validate($all); if (!$validate->passes()) { return redirect()->back()->withInput()->withErrors($validate); } $Id = $this->repo->postOfId($all['id']); if (!is_null($Id)) { $this->repo->update($Id, $all); Session::flash('msg', 'edit success'); } else { $this->repo->create($this->repo->perpare_data($all)); Session::flash('msg', 'add success'); } return redirect()->back(); } public function retrieve() { return View('admin.index')->with(['Data' => $this->repo->retrieve()]); } public function delete() { $id = Input::get('id'); $data = $this->repo->postOfId($id); if (!is_null($data)) { $this->repo->delete($data); Session::flash('msg', 'operation Success'); return redirect()->back(); } else { return redirect()->back()->withErrors('operationFails'); } } }
如您所见,我使用 Flash 助手来管理消息(您可以使用 Laravel 的)。关于验证器,我应该补充一点,您可以创建自己的验证器(就像我一样)或使用 Laravel 默认值,具体取决于您的偏好。
查看文件与平常相同。在此示例视图中,文件看起来像 resources/views/admin/edit.blade.php
@if (Session::has('flash_notification.message')) × {!! Session::get('flash_notification.message') !!} @endif @if($errors->has()) @foreach ($errors->all() as $error) {!! $error !!} @endforeach @endif {!! 'title' !!} {!! 'Body' !!} {!! is_object($ListData)?$ListData->getTitle():'' !!} {!! 'save' !!}
AppEntitiesPost.php
: 🎜
rrreee
🎜Kini tiba masanya untuk mencipta 🎜repositori🎜, yang diterangkan sebelum ini. App/Repositories/PostRepo.php
:🎜
rrreee
🎜Pengawal: App/Http/Controllers/PostController.php
:🎜
rrreee
🎜Seperti yang anda lihat, saya menggunakan Flash Assistant untuk mengurus mesej (anda boleh menggunakan Laravel's). Mengenai pengesah, saya harus menambah bahawa anda boleh membuat sendiri (seperti yang saya lakukan) atau menggunakan lalai Laravel, bergantung pada pilihan anda. 🎜
🎜Lihat fail seperti biasa. Dalam paparan contoh ini, fail kelihatan seperti resources/views/admin/edit.blade.php
:🎜
rrreee🎜Atas ialah kandungan terperinci Mod pergudangan dalam Laravel 5. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!