Rumah >pembangunan bahagian belakang >tutorial php >Bagaimana untuk Mendapatkan Rekod Dalam Julat Tarikh Tertentu Menggunakan ORM Fasih Laravel?

Bagaimana untuk Mendapatkan Rekod Dalam Julat Tarikh Tertentu Menggunakan ORM Fasih Laravel?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-12-08 07:49:13685semak imbas

How to Retrieve Records Within a Specific Date Range Using Laravel's Eloquent ORM?

Mengambil Rekod Berdasarkan Julat Tarikh Menggunakan Laravel

Untuk mendapatkan semula rekod yang termasuk dalam julat tarikh yang ditentukan, Laravel's Eloquent ORM menyediakan whereBetween kaedah. Kaedah ini membolehkan anda menentukan nama lajur dan tatasusunan dua tarikh, mewakili titik mula dan tamat julat yang diingini.

$from = date('2018-01-01');
$to = date('2018-05-02');

Reservation::whereBetween('reservation_from', [$from, $to])
    ->get();

Pertanyaan ini akan mendapatkan semula semua tempahan yang nilai reservation_from jatuh antara Januari 1, 2018 dan 2 Mei, 2018.

Julat Dinamik Parameter

Anda juga boleh mentakrifkan tarikh mula dan tamat julat secara dinamik menggunakan kaedah antara Carbon:

Reservation::all()
    ->filter(function($item) {
        if (Carbon::now()->between($item->from, $item->to)) {
            return $item;
        }
    });

Pertanyaan Tambahan

  • whereOrBetween: Menentukan julat tarikh tambahan keadaan.
  • whereNotBetween: Tidak termasuk selang tarikh tertentu.

Contoh:

Reservation::whereBetween('reservation_from', [$from1, $to1])
    ->orWhereBetween('reservation_to', [$from2, $to2])
    ->whereNotBetween('reservation_to', [$from3, $to3])
    ->get();

Lain-lain Klausa Dimana

Untuk fleksibiliti lanjut, Laravel menawarkan WHERE tambahan klausa, termasuk:

  • whereIn
  • whereNotIn
  • whereNull
  • whereNotNull
  • whereDate
  • whereM onth
  • whereDay
  • whereYear
  • whereTime
  • whereColumn
  • whereWujud
  • whereRaw

Atas ialah kandungan terperinci Bagaimana untuk Mendapatkan Rekod Dalam Julat Tarikh Tertentu Menggunakan ORM Fasih Laravel?. 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