Rumah pembangunan bahagian belakang tutorial php Asas Pemetaan Hubungan Objek (ORM): Memahami Doktrin ORM

Asas Pemetaan Hubungan Objek (ORM): Memahami Doktrin ORM

Jun 19, 2023 pm 03:43 PM
orm doctrine pemetaan hubungan

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

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

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

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

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());
}
Salin selepas log masuk

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!

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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

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

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Rangka kerja ORM Kura-kura ORM dalam Python dalam amalan Rangka kerja ORM Kura-kura ORM dalam Python dalam amalan Jun 10, 2023 pm 06:05 PM

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.

Bagaimana untuk menggunakan pemetaan hubungan objek (ORM) dalam PHP untuk memudahkan operasi pangkalan data? Bagaimana untuk menggunakan pemetaan hubungan objek (ORM) dalam PHP untuk memudahkan operasi pangkalan data? May 07, 2024 am 08:39 AM

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.

ORM dalam PHP ORM dalam PHP May 24, 2023 am 08:14 AM

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.

Bagaimanakah Hibernate melaksanakan pemetaan polimorfik? Bagaimanakah Hibernate melaksanakan pemetaan polimorfik? Apr 17, 2024 pm 12:09 PM

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.

Apakah mekanisme ORM bagi rangka kerja Java Hibernate? Apakah mekanisme ORM bagi rangka kerja Java Hibernate? Apr 17, 2024 pm 02:39 PM

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.

Apakah kelemahan rangka kerja ORM Hibernate? Apakah kelemahan rangka kerja ORM Hibernate? Apr 18, 2024 am 08:30 AM

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.

Bagaimana pemetaan hubungan objek PHP dan lapisan abstraksi pangkalan data meningkatkan kebolehbacaan kod Bagaimana pemetaan hubungan objek PHP dan lapisan abstraksi pangkalan data meningkatkan kebolehbacaan kod May 06, 2024 pm 06:06 PM

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.

Bagaimana untuk menggunakan ORM (Pemetaan Hubungan Objek) dalam rangka kerja Phalcon? Bagaimana untuk menggunakan ORM (Pemetaan Hubungan Objek) dalam rangka kerja Phalcon? Jun 03, 2023 pm 09:21 PM

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

See all articles