Mod pergudangan dalam Laravel 5

PHPz
Lepaskan: 2023-08-28 15:14:01
asal
1397 orang telah melayarinya

Laravel 5中的仓储模式

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.

doktrin ORM

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.

Dogma dan Kefasihan Kata

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.

Apl Blog

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
Salin selepas log masuk

Seperti biasa, pakej ini harus ditambahkan pada app/config.php sebagai penyedia perkhidmatan: app/config.php ,作为服务提供者:

LaravelDoctrine\ORM\DoctrineServiceProvider::class,
Salin selepas log masuk

还应该配置别名:

'EntityManager' => LaravelDoctrine\ORM\Facades\EntityManager::class
Salin selepas log masuk

最后,我们发布包配置:

php artisan vendor:publish --tag="config"
Salin selepas log masuk

现在我们已经完成了。

实体是应用程序 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;
    }
}
Salin selepas log masuk

现在是时候创建存储库了,这在前面已经描述过了。 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);
    }
}

Salin selepas log masuk

控制器: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');
        }
    }
}
Salin selepas log masuk

如您所见,我使用 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' !!}
                        
                    
                
                
            
        
Salin selepas log masuk
Alias ​​juga harus dikonfigurasikan: rrreee 🎜Akhir sekali, kami menerbitkan konfigurasi pakej: 🎜 rrreee 🎜Sekarang kita sudah selesai. 🎜 🎜Entiti ialah bahagian penting dalam aplikasi 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!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!