Dengan perkembangan Internet, pembangunan aplikasi web telah menjadi teras pembangunan perisian moden. Disebabkan oleh kerumitan logik perniagaan, pembangun memerlukan banyak alat dan teknologi untuk memudahkan kod dan meningkatkan kecekapan. Dalam hal ini, menggunakan Eloquent ORM boleh memudahkan kod lapisan perniagaan. Dalam artikel ini, kami akan memperkenalkan cara menggunakan Eloquent dalam ThinkPHP6 untuk memudahkan lapisan perniagaan.
Apa itu Fasih?
Eloquent ialah alat ORM (Object Relational Mapping) yang berkuasa yang dibangunkan oleh Laravel. Ia membolehkan pembangun mengendalikan pangkalan data melalui sintaks yang ringkas dan intuitif tanpa perlu menulis pernyataan SQL yang kompleks. Eloquent secara automatik memetakan data dalam jadual data ke dalam objek PHP yang sepadan, membenarkan pembangun memproses data dalam cara pengaturcaraan berorientasikan objek (OOP).
Menggunakan Eloquent dalam ThinkPHP6
Dalam ThinkPHP6, Eloquent boleh digunakan dengan memasang komponen ORM rangka kerja Laravel. Berikut ialah langkah-langkah untuk menggunakan Eloquent:
Masukkan arahan berikut dalam terminal untuk memasang komponen ORM rangka kerja Laravel :
composer require illuminate/database
Tetapkan sambungan pangkalan data dalam fail /config/database.php, contohnya:
'connections' => [ 'mysql' => [ 'driver' => 'mysql', 'url' => env('DATABASE_URL'), 'host' => env('DB_HOST', '127.0.0.1'), 'port' => env('DB_PORT', '3306'), 'database' => env('DB_DATABASE', 'forge'), 'username' => env('DB_USERNAME', 'forge'), 'password' => env('DB_PASSWORD', ''), 'unix_socket' => env('DB_SOCKET', ''), 'charset' => 'utf8mb4', 'collation' => 'utf8mb4_unicode_ci', 'prefix' => '', 'strict' => true, 'engine' => null, ], ],
Buat kelas model yang sepadan dalam folder /app/Models. Contohnya, jika kita mempunyai jadual data yang dipanggil "pengguna", kita boleh mencipta kelas model yang dipanggil "Pengguna" dengan kod berikut:
namespace appmodels; use IlluminateDatabaseEloquentModel; class User extends Model { //指定表名 protected $table = 'users'; //指定主键 protected $primaryKey = 'id'; //是否使用自增主键 public $incrementing = true; //是否需要自动维护时间戳 public $timestamps = true; }
Dalam kod di atas, "$table" menentukan jadual yang sepadan dengan nama kelas model, "$primaryKey" menentukan nama kunci utama, "$incrementing" menentukan sama ada untuk menggunakan kunci utama auto-incrementing dan "$timestamps" menentukan sama ada penyelenggaraan automatik cap waktu diperlukan.
Dalam pengawal, kita boleh menggunakan Eloquent dengan cara berikut:
... use appmodelsUser; class UserController extends Controller { public function index() { $users = User::where('status', '=', 1) ->orderBy('name') ->get(); return view('user.index', ['users' => $users]); } public function show($id) { $user = User::find($id); return view('user.show', ['user' => $user]); } ... }
Dalam kod di atas, The " di mana" kaedah digunakan untuk menambah syarat pertanyaan, kaedah "orderBy" digunakan untuk menambah syarat pengisihan dan kaedah "dapat" digunakan untuk melaksanakan pertanyaan. Selain itu, kaedah "cari" digunakan untuk mencari rekod yang ditentukan mengikut kunci utama.
Ringkasan
Dalam artikel ini, kami memperkenalkan cara menggunakan Eloquent dalam ThinkPHP6 untuk memudahkan kod lapisan perniagaan. Dengan menggunakan Eloquent, kita boleh menggunakan pendekatan berorientasikan objek untuk memproses data, mengelak daripada menulis pernyataan SQL yang kompleks dan meningkatkan kebolehbacaan dan kebolehselenggaraan kod. Jika anda ingin mengetahui lebih lanjut tentang Eloquent, anda boleh merujuk kepada dokumentasi Laravel rasmi (https://laravel.com/docs/8.x/eloquent).
Atas ialah kandungan terperinci Cara menggunakan Eloquent untuk memudahkan lapisan perniagaan dalam ThinkPHP6. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!