Rumah > rangka kerja php > Laravel > Bagaimana untuk menggunakan laravel hasManyThrough untuk menghuraikan?

Bagaimana untuk menggunakan laravel hasManyThrough untuk menghuraikan?

藏色散人
Lepaskan: 2022-01-26 11:35:13
ke hadapan
2701 orang telah melayarinya

Berikut ialah pengenalan kepada penggunaan dan parameter laravel hasManyThrough daripada lajur tutorial Laravel saya harap ia dapat membantu anda!

Kes pertama, saya panggil jadual persatuan konduktif (mod ringkas)

Terdapat ramai pengguna di negara ini, dan pengguna mempunyai banyak siaran

countries
    id - integer
    name - string

users
    id - integer
    country_id - integer
    name - string

posts
    id - integer
    user_id - integer
    title - string
Salin selepas log masuk

Bagaimana untuk menanyakan semua siaran di negara tertentu?

negara ialah jadual ini, siaran ialah jadual sasaran untuk dikeluarkan, pengguna ialah jadual perantaraan

return $this->hasManyThrough('App\Post', 'App\User', 'country_id', 'user_id');
Salin selepas log masuk

Kes kedua, terdapat jadual perantaraan (jadual perantaraan tulen )

exam_paper(试卷表)id
nameexam_paper_question(试卷与试题中间表)id
exam_paper_id
question_idexam_question(试题表)id
name
Salin selepas log masuk

Kita perlu menanyakan soalan

return $this->hasManyThrough('exam_question', 'exam_paper_question', 'exam_paper_id', 'id','id','question_id');
Salin selepas log masuk
// 参数1 目标表类名
exam_question,
// 参数2 枢纽表类名
exam_paper_question,
// 参数3 枢纽表中和当前表关联的字段名
'exam_paper_question.exam_paper_id',
// 参数4 目标表和枢纽表关联的字段名
'exam_question.id',
// 参数5 当前表中和枢纽表关联的字段名
'exam_paper.id',
// 参数6 枢纽表和目标表关联的字段名
'exam_paper_question.question_id');
Salin selepas log masuk

dengan id kertas_peperiksaan Jika jadual semasa ditandakan sebagai A, jadual sasaran ditanda sebagai B, dan jadual perantaraan ditandakan sebagai C , 6 parameter direkodkan sebagai (B, C, CA, BC, AC, CB)

Pembelajaran yang disyorkan: "tutorial video laravel "

Atas ialah kandungan terperinci Bagaimana untuk menggunakan laravel hasManyThrough untuk menghuraikan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:learnku.com
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
Isu terkini
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan