


Cara menggunakan ThinkPHP6 untuk melaksanakan ORM untuk mengesahkan operasi pangkalan data secara automatik
Memandangkan fungsi aplikasi web terus meningkat, pembangun selalunya perlu menghabiskan banyak masa menulis peraturan pengesahan pangkalan data. Menggunakan rangka kerja ORM (Pemetaan Perhubungan Objek), peraturan pengesahan pangkalan data dan logik perniagaan boleh diasingkan, menjimatkan masa dan meningkatkan kecekapan pembangunan. Antaranya, ThinkPHP6 menyediakan fungsi pengesahan automatik, yang boleh membantu kami melaksanakan operasi pangkalan data pengesahan automatik ORM dengan cepat. Seterusnya, kami akan memperkenalkan cara menggunakan ThinkPHP6 untuk melaksanakan ORM untuk mengesahkan operasi pangkalan data secara automatik.
- Pasang ThinkPHP6
Mula-mula, kita perlu memasang ThinkPHP6. Anda boleh menggunakan Composer untuk memasang ThinkPHP6 melalui arahan berikut:
composer create-project topthink/think tp6 --prefer-dist
Sudah tentu, anda juga boleh memuat turun sumber rangka kerja terkini dari laman web rasmi ThinkPHP6 (https://www .thinkphp.cn) kod.
- Mengkonfigurasi sambungan pangkalan data
Sebelum melaksanakan pengesahan automatik ORM, kami perlu mengkonfigurasi sambungan pangkalan data terlebih dahulu. Ia boleh dikonfigurasikan dalam config/database.php
dalam direktori akar projek, contohnya:
return [ // 数据库类型 'type' => 'mysql', // 数据库连接DSN配置 'dsn' => '', // 服务器地址 'hostname' => '127.0.0.1', // 数据库名 'database' => 'test', // 数据库用户名 'username' => 'root', // 数据库密码 'password' => 'password', // 数据库连接端口 'hostport' => '3306', // 数据库连接参数 'params' => [], // 数据库编码默认采用utf8 'charset' => 'utf8', // 数据库表前缀 'prefix' => '', // 数据库调试模式 'debug' => true, // 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器) 'deploy' => 0, // 数据库读写是否分离 主从式有效 'rw_separate' => false, // 读写分离后 主服务器数量 'master_num' => 1, // 指定从服务器序号 'slave_no' => '', // 是否严格检查字段是否存在 'fields_strict' => true, // 数据集返回类型 'resultset_type' => 'array', // 是否自动写入时间戳字段 'auto_timestamp' => false, // 是否需要进行SQL性能分析 'sql_explain' => false, // 开启断线重连 'break_reconnect' => true, ];
- Buat dan gunakan model
Dalam ThinkPHP6, gunakan model untuk berinteraksi dengan pangkalan data . Anda boleh mencipta model melalui arahan berikut:
php bin/think make:model Test
Arahan ini akan mencipta fail app
dalam direktori Test.php
, yang mengandungi kelas model kosong Test
. Kita boleh menentukan nama jadual operasi pangkalan data, nama kunci utama, cap masa automatik dan definisi lain dalam kelas ini. Contohnya:
<?php namespace appmodel; use thinkModel; class Test extends Model { // 指定表名 protected $table = 'test'; // 指定主键名 protected $pk = 'id'; // 自动时间戳 protected $autoWriteTimestamp = true; }
Dalam kelas model ini, kita juga boleh mentakrifkan beberapa peraturan pengesahan data. Contohnya:
<?php namespace appmodel; use thinkModel; class Test extends Model { // 指定表名 protected $table = 'test'; // 指定主键名 protected $pk = 'id'; // 自动时间戳 protected $autoWriteTimestamp = true; // 定义验证规则 protected $validate=[ 'name'=>'require|max:10', 'age'=>'require|integer|between:1,100', 'email'=>'email', ]; }
Dalam contoh ini, kami mentakrifkan tiga peraturan pengesahan: name
Diperlukan, panjang maksimum ialah 10 age
Diperlukan, mestilah integer, nilainya antara 1 dan 100; 🎜>Mesti dalam format e-mel. Peraturan ini akan disahkan secara automatik apabila beroperasi pada data model. email
- Gunakan fungsi pengesahan automatik
// 添加数据 $data = [ 'name' => '张三', 'age' => '18', 'email'=> 'zhangsan@test.com', ]; $model = new Test; $result = $model->save($data); if ($result) { echo '数据添加成功'; } else { echo '数据添加失败'; } // 更新数据 $data = [ 'id' => 1, 'name' => '李四', 'age' => '20', 'email'=> 'lisi@test.com', ]; $model = new Test; $result = $model->save($data, ['id' => 1]); if ($result) { echo '数据更新成功'; } else { echo '数据更新失败'; } // 删除数据 $model = new Test; $result = $model->destroy(1); if ($result) { echo '数据删除成功'; } else { echo '数据删除失败'; } // 查询数据 $model = new Test; $result = $model->where('id', 1)->find(); if ($result) { echo '数据查询成功'; } else { echo '数据查询失败'; }
- Mesej pengesahan tersuai
dalam kelas model. Contohnya: message
<?php namespace appmodel; use thinkModel; class Test extends Model { // 指定表名 protected $table = 'test'; // 指定主键名 protected $pk = 'id'; // 自动时间戳 protected $autoWriteTimestamp = true; // 定义验证规则 protected $validate=[ 'name'=>'require|max:10', 'age'=>'require|integer|between:1,100', 'email'=>'email', ]; // 定义验证失败消息 protected $message = [ 'name.require' => '姓名不能为空', 'name.max' => '姓名长度不能超过10个字符', 'age.require' => '年龄不能为空', 'age.integer' => '年龄必须为整数', 'age.between' => '年龄取值必须在1到100之间', 'email.email' => ' email格式不正确 ', ]; }
Atas ialah kandungan terperinci Cara menggunakan ThinkPHP6 untuk melaksanakan ORM untuk mengesahkan operasi pangkalan data secara automatik. 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

Untuk menjalankan projek ThinkPHP, anda perlu: memasang Komposer untuk mencipta projek, masukkan direktori projek dan laksanakan php bin/console serve;

ThinkPHP mempunyai berbilang versi yang direka untuk versi PHP yang berbeza. Versi utama termasuk 3.2, 5.0, 5.1 dan 6.0, manakala versi kecil digunakan untuk membetulkan pepijat dan menyediakan ciri baharu. Versi stabil terkini ialah ThinkPHP 6.0.16. Apabila memilih versi, pertimbangkan versi PHP, keperluan ciri dan sokongan komuniti. Adalah disyorkan untuk menggunakan versi stabil terkini untuk prestasi dan sokongan terbaik.

Langkah-langkah untuk menjalankan ThinkPHP Framework secara setempat: Muat turun dan nyahzip ThinkPHP Framework ke direktori tempatan. Buat hos maya (pilihan) yang menunjuk ke direktori akar ThinkPHP. Konfigurasikan parameter sambungan pangkalan data. Mulakan pelayan web. Mulakan aplikasi ThinkPHP. Akses URL aplikasi ThinkPHP dan jalankannya.

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.

Perbandingan prestasi rangka kerja Laravel dan ThinkPHP: ThinkPHP umumnya berprestasi lebih baik daripada Laravel, memfokuskan pada pengoptimuman dan caching. Laravel berfungsi dengan baik, tetapi untuk aplikasi yang kompleks, ThinkPHP mungkin lebih sesuai.

Langkah pemasangan ThinkPHP: Sediakan persekitaran PHP, Komposer dan MySQL. Buat projek menggunakan Komposer. Pasang rangka kerja dan kebergantungan ThinkPHP. Konfigurasikan sambungan pangkalan data. Hasilkan kod aplikasi. Lancarkan aplikasi dan lawati http://localhost:8000.

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.
