


Asas Pemetaan Hubungan Objek (ORM): Memahami Doktrin ORM
Asas Pemetaan Perhubungan Objek (ORM): Memahami Doktrin ORM
Apabila kami membangunkan aplikasi, kami perlu mengendalikan pangkalan data untuk menyimpan dan mendapatkan semula data. Walau bagaimanapun, adalah menyusahkan untuk menggunakan kod pertanyaan pangkalan data asal secara langsung. Kita perlu mewujudkan hubungan pemetaan antara objek dan data Ini adalah peranan ORM. ORM secara automatik memetakan dan menukar objek dan jadual pangkalan data, membolehkan manipulasi data mudah, menjadikan kod kami lebih mudah untuk diselenggara.
Doktrin ORM ialah salah satu rangka kerja ORM yang paling popular dalam PHP. Ia menggunakan kaedah yang mudah tetapi berkesan untuk memetakan objek PHP dan jadual pangkalan data, menyediakan API yang mudah digunakan untuk operasi CRUD.
Artikel ini akan memperkenalkan beberapa pengetahuan asas tentang ORM Doktrin, termasuk konfigurasi, entiti, pemetaan, pertanyaan, dsb.
Konfigurasi
Sebelum kita mula, kita perlu memasang Doktrin ORM. Ia boleh dipasang melalui Komposer, menggunakan arahan berikut:
composer require doctrine/orm
Seterusnya, dalam fail PHP kami, kami perlu memulakan Doktrin. Ini boleh dilakukan melalui kod berikut:
use DoctrineORMToolsSetup; use DoctrineORMEntityManager; require_once "vendor/autoload.php"; $paths = array("path/to/entity-files"); $isDevMode = false; // the connection configuration $dbParams = array( 'driver' => 'pdo_mysql', 'user' => 'your_database_user', 'password' => 'your_database_password', 'dbname' => 'your_database_name', ); $config = Setup::createAnnotationMetadataConfiguration($paths, $isDevMode); $entityManager = EntityManager::create($dbParams, $config);
Dalam kod di atas, kami mula-mula menentukan laluan ke fail entiti. Kami kemudiannya menentukan parameter sambungan pangkalan data seperti pemacu, nama pengguna, kata laluan dan nama pangkalan data. Akhir sekali, kami menggunakan fungsi Setup::createAnnotationMetadataConfiguration() untuk mengkonfigurasi metadata, dan kemudian menggunakan fungsi EntityManager::create() untuk mencipta pengurus entiti.
Entiti
Malah, Model dan Entiti adalah perkara yang sama. Kita perlu mencipta kelas entiti untuk memetakan jadual pangkalan data. Kelas ini perlu mewarisi kelas DoctrineORMMappingClassMetadata dan menggunakan anotasi DoctrineORMMappingEntity dan DoctrineORMMappingTable.
use DoctrineORMMapping as ORM; /** * @ORMEntity * @ORMTable(name="users") */ class User { /** * @ORMId * @ORMGeneratedValue * @ORMColumn(type="integer") */ private $id; /** * @ORMColumn(type="string") */ private $name; /** * @ORMColumn(type="string", length=100, unique=true) */ private $email; // ... getters and setters }
Dalam kod di atas, kami telah menentukan kelas entiti Pengguna yang akan memetakan jadual pangkalan data bernama "pengguna". Ia mempunyai tiga atribut: $id, $name dan $email. Anotasi memberitahu Doktrin ORM cara memetakan sifat ini, contohnya sifat $id ialah kunci utama dan dinaikkan secara automatik, sifat $name dipetakan ke lajur pangkalan data jenis varchar, sifat $e-mel dipetakan untuk menaip varchar dan mestilah unik dalam jadual pangkalan data.
Pemetaan
Selepas kita mentakrifkan entiti, kita perlu memberitahu Doktrin ORM cara memetakan entiti ke jadual pangkalan data. Kita boleh menggunakan XML, ulasan atau YAML untuk menentukan hubungan pemetaan.
Di sini, kami menggunakan anotasi untuk menentukan hubungan pemetaan. Sebagai contoh, dalam kod di bawah, kami mentakrifkan hubungan pemetaan untuk memetakan entiti Pengguna ke users
jadual pangkalan data:
/** * @ORMEntity * @ORMTable(name="users") */ class User { // properties ... // many-to-one association /** * @ORMManyToOne(targetEntity="Department") * @ORMJoinColumn(name="department_id", referencedColumnName="id") */ private $department; }
Dalam kod di atas, kami mentakrifkan hubungan pemetaan antara entiti Pengguna dan Jabatan entiti Perhubungan banyak-dengan-satu. Semua definisi perhubungan pemetaan perlu ditandakan dengan anotasi.
Pertanyaan
Doktrin ORM menyediakan API pertanyaan yang mudah digunakan yang membolehkan kami melaksanakan operasi CRUD dengan mudah. Sebagai contoh, kod berikut menunjukkan cara untuk menanyakan entiti menggunakan Doktrin:
$userRepository = $entityManager->getRepository('User'); $users = $userRepository->findAll(); foreach ($users as $user) { echo sprintf("-%s ", $user->getName()); }
Dalam kod di atas, kami menggunakan pembolehubah $entityManager untuk mendapatkan contoh repositori Pengguna. Kami kemudian mendapatkan semula semua kejadian Pengguna menggunakan kaedah findAll(), mencetak nama pengguna setiap tika.
Ringkasan
Artikel ini memperkenalkan pengetahuan asas ORM Doktrin, termasuk konfigurasi, entiti, pemetaan dan pertanyaan. ORM ialah alat yang sangat berkuasa yang boleh memudahkan pengekodan fungsi berkaitan pangkalan data. Saya harap artikel ini akan membantu anda memahami ORM, dan saya harap anda boleh mengetahui lebih lanjut tentang Doktrin ORM dan mula menggunakannya.
Atas ialah kandungan terperinci Asas Pemetaan Hubungan Objek (ORM): Memahami Doktrin ORM. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

TortoiseORM ialah rangka kerja ORM asynchronous yang dibangunkan berdasarkan bahasa Python dan boleh digunakan untuk mengurus pangkalan data hubungan dalam aplikasi asynchronous Python. Artikel ini akan memperkenalkan cara menggunakan rangka kerja TortoiseORM untuk mencipta, membaca, mengemas kini dan memadam data Anda juga akan mempelajari cara melakukan pertanyaan mudah dan kompleks daripada pangkalan data hubungan. Persediaan Sebelum memulakan tutorial ini, anda perlu memasang Python (Python3.6+ disyorkan) dan memasang TortoiseOR.

Operasi pangkalan data dalam PHP dipermudahkan menggunakan ORM, yang memetakan objek ke dalam pangkalan data hubungan. EloquentORM dalam Laravel membolehkan anda berinteraksi dengan pangkalan data menggunakan sintaks berorientasikan objek Anda boleh menggunakan ORM dengan mentakrifkan kelas model, menggunakan kaedah Eloquent atau membina sistem blog dalam amalan.

Dengan perkembangan Internet, pembangunan aplikasi Web secara beransur-ansur telah digunakan secara meluas. Salah satu bahasa yang paling penting ialah PHP. Walau bagaimanapun, pengurusan dan pemprosesan data sentiasa menjadi masalah yang dihadapi oleh pembangun. Atas sebab ini, ORM telah menjadi pilihan yang baik untuk pemprosesan data. Apakah ORM? ORM adalah singkatan kepada Object-Relational Mapping Ia adalah kaedah menukar objek dalam program bahasa pengaturcaraan berorientasikan objek dengan menggunakan metadata yang menerangkan pemetaan antara objek dan pangkalan data.

Pemetaan polimorfik hibernate boleh memetakan kelas yang diwarisi ke pangkalan data dan menyediakan jenis pemetaan berikut: subkelas bercantum: Cipta jadual berasingan untuk subkelas, termasuk semua lajur kelas induk. table-per-class: Cipta jadual berasingan untuk subkelas, yang mengandungi hanya lajur khusus subkelas. union-subclass: serupa dengan joined-subclass, tetapi jadual kelas induk menggabungkan semua lajur subclass.

Hibernate ialah rangka kerja JavaORM untuk pemetaan antara objek Java dan pangkalan data hubungan. Mekanisme ORMnya merangkumi langkah-langkah berikut: Anotasi/Konfigurasi: Kelas objek ditandakan dengan anotasi atau fail XML, menyatakan jadual dan lajur pangkalan datanya yang dipetakan. Kilang sesi: menguruskan sambungan antara Hibernate dan pangkalan data. Sesi: Mewakili sambungan aktif ke pangkalan data dan digunakan untuk melaksanakan operasi pertanyaan dan kemas kini. Kegigihan: Simpan data ke pangkalan data melalui kaedah simpan() atau kemas kini(). Pertanyaan: Gunakan Kriteria dan HQL untuk menentukan pertanyaan kompleks untuk mendapatkan semula data.

Rangka kerja HibernateORM mempunyai kekurangan berikut: 1. Penggunaan memori yang besar kerana ia menyimpan hasil pertanyaan dan objek entiti 2. Kerumitan tinggi, memerlukan pemahaman mendalam tentang seni bina dan konfigurasi 3. Kelewatan pemuatan tertunda, yang membawa kepada kelewatan yang tidak dijangka; . Kesesakan prestasi, pada bulan Mei berlaku apabila sejumlah besar entiti dimuatkan atau dikemas kini pada masa yang sama 5. Pelaksanaan khusus vendor, mengakibatkan perbezaan antara pangkalan data.

Jawapan: ORM (Pemetaan Hubungan Objek) dan DAL (Lapisan Abstraksi Pangkalan Data) meningkatkan kebolehbacaan kod dengan mengabstraksikan butiran pelaksanaan pangkalan data yang mendasari. Penerangan terperinci: ORM menggunakan pendekatan berorientasikan objek untuk berinteraksi dengan pangkalan data, membawa kod lebih dekat dengan logik aplikasi. DAL menyediakan antara muka biasa yang bebas daripada vendor pangkalan data, memudahkan interaksi dengan pangkalan data yang berbeza. Menggunakan ORM dan DAL boleh mengurangkan penggunaan pernyataan SQL dan menjadikan kod lebih ringkas. Dalam kes praktikal, ORM dan DAL boleh memudahkan pertanyaan maklumat produk dan meningkatkan kebolehbacaan kod.

Dengan pembangunan berterusan aplikasi web, rangka kerja pembangunan web yang sepadan juga muncul. Antaranya, rangka kerja Phalcon digemari oleh semakin ramai pembangun kerana prestasi tinggi dan fleksibilitinya. Rangka kerja Phalcon menyediakan banyak komponen berguna, antaranya ORM (Pemetaan Perhubungan Objek) dianggap sebagai salah satu yang paling penting. Artikel ini akan memperkenalkan cara menggunakan ORM dalam rangka kerja Phalcon dan beberapa contoh aplikasi praktikal. Apa itu ORM Pertama, kita perlu faham apa itu ORM. ORM ialah Object-Rel
