Rumah >rangka kerja php >ThinkPHP >Mari bercakap tentang kod pertanyaan dalam thinkphp

Mari bercakap tentang kod pertanyaan dalam thinkphp

PHPz
PHPzasal
2023-04-07 09:31:00543semak imbas

ThinkPHP ialah rangka kerja PHP yang sangat baik berdasarkan model pembangunan MVC Ia menggunakan teknologi yang sangat baik seperti ORM dan enjin templat semasa proses pembangunan, yang meningkatkan kecekapan pembangunan dan kualiti kod. Semasa proses pembangunan, kita selalunya perlu menanyakan rekod dalam pangkalan data Artikel ini akan memperkenalkan kod pertanyaan dalam ThinkPHP.

  1. Menyiasat rekod tunggal

Menyoal rekod tunggal ialah kod yang sering kami gunakan dan boleh dilaksanakan menggunakan kaedah find(). Kaedah find() mengembalikan objek model, yang boleh kita kendalikan secara langsung.

Sebagai contoh, kami ingin menanyakan rekod dengan id 1 dalam jadual pengguna Kodnya adalah seperti berikut:

$user = UserModel::where('id', 1)->find();

Antaranya, UserModel ialah kelas model pengguna yang kami. ditakrifkan, dan where('id', 1) menentukan syarat, find() bermaksud menanyakan hanya satu rekod.

  1. Menyiasat berbilang rekod

Ia juga sangat mudah untuk menanyakan berbilang rekod Kami boleh menggunakan kaedah pilih() untuk mencapai ini. Kaedah select() mengembalikan objek set data, yang juga boleh dikendalikan secara langsung.

Sebagai contoh, kami ingin menanyakan semua rekod dalam jadual pengguna Kodnya adalah seperti berikut:

$users = UserModel::select();

Antaranya, UserModel ialah kelas model pengguna yang kami takrifkan tiada syarat pertanyaan dinyatakan, pertanyaan lalai ialah Semua rekod.

Kami juga boleh menentukan syarat pertanyaan, contohnya, menanya semua rekod dengan id lebih besar daripada 1:

$users = UserModel::where('id', '>', 1)->select();

Selain itu, kami juga boleh memanggil kaedah pertanyaan dalam rantai, contohnya , tanya semua rekod dalam jadual pengguna Rekod dengan id lebih besar daripada 1 dan status 1:

$users = UserModel::where('id', '>', 1)->where('status', 1)->select();
  1. Pertanyaan medan yang ditentukan

Kadangkala kita hanya memerlukan nilai medan tertentu semasa membuat pertanyaan, ini Kita boleh menggunakan kaedah medan() untuk menentukan medan pertanyaan.

Sebagai contoh, kita hanya perlu menanyakan medan id dan nama semua pengguna dalam jadual pengguna Kodnya adalah seperti berikut:

$users = UserModel::field('id,name')->select();
  1. Pertanyaan halaman
  2. .

Apabila jumlah data adalah besar, kami perlu menomborkan hasil pertanyaan untuk meningkatkan kelajuan pemuatan halaman dan pengalaman pengguna. ThinkPHP menyediakan komponen easySwoole/easySwoole/penomboran, yang mudah dan mudah digunakan.

Sebagai contoh, kita perlu menanyakan data semua pengguna dalam jadual pengguna dan menggunakan easySwoole/easySwoole/penomboran untuk halaman kod adalah seperti berikut:

use think\facade\Db;
use easySwoole\pagination\Paginator;

// 设置每页显示的记录数
$perPage = 10;

// 获取总记录数
$total = Db::name('user')->count();

// 创建分页器对象
$paginator = new Paginator($total, $perPage);

// 获取分页数据
$users = Db::name('user')
    ->limit($paginator->getLimit())
    ->page($paginator->getCurrentPage())
    ->select();

Antaranya, limit() dan page() Kaedah digunakan untuk mengehadkan julat pertanyaan dan menanyakan data halaman yang ditentukan Kaedah getLimit() dan getCurrentPage() digunakan untuk mendapatkan maklumat status alat kelui semasa.

  1. Pertanyaan pengagregatan

Apabila membuat pertanyaan, kadangkala anda perlu mengagregatkan hasil pertanyaan, seperti purata, maksimum, minimum, dsb. Dalam ThinkPHP, kita boleh menggunakan fungsi agregat untuk mencapai ini.

Sebagai contoh, tanya umur purata semua pengguna dalam jadual pengguna:

use think\facade\Db;

$avgAge = Db::name('user')->avg('age'); // 返回结果是一个浮点数

Anda juga boleh menggunakan fungsi agregat untuk melaksanakan pertanyaan bersyarat, seperti menanyakan nilai maksimum umur medan:

use think\facade\Db;

$maxAge = Db::name('user')->where('status', 1)->max('age'); // 返回结果是一个整数

Di atas ialah kod pertanyaan yang biasa digunakan dalam ThinkPHP saya harap ia akan membantu anda.

Atas ialah kandungan terperinci Mari bercakap tentang kod pertanyaan dalam thinkphp. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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