Laravel Advanced Wheres จะส่งผ่านตัวแปรไปยังฟังก์ชันได้อย่างไร?


87

ตัวอย่างในเอกสาร:

DB::table('users')
        ->whereExists(function($query)
        {
            $query->select(DB::raw(1))
                  ->from('orders')
                  ->whereRaw('orders.user_id = users.id');
        })
        ->get();

แต่ถ้าฉันต้องการใช้ตัวแปรภายนอกเช่นนั้น:

            ->where('city_id', '=', $this->city->id)
            ->where(function($query)
                {
                    $query->where('name', 'LIKE', '%'.$searchQuery.'%')
                    ->orWhere('address', 'LIKE', '%'.$searchQuery.'%')

                })

ตอนนี้ฉันสร้างพร็อพเพอร์ตี้ใหม่และเข้าถึงผ่าน$this->แต่มีวิธีไหนที่สะดวกกว่านี้อีกไหม

คำตอบ:


230

คุณสามารถส่งผ่านตัวแปรที่จำเป็นจากขอบเขตหลักไปสู่การปิดด้วยuseคีย์เวิร์ด

ตัวอย่างเช่น:

DB::table('users')->where(function ($query) use ($activated) {
    $query->where('activated', '=', $activated);
})->get();

เพิ่มเติมเกี่ยวกับที่นี่

แก้ไข (อัปเดต 2019):

PHP 7.4 (จะเปิดตัวในวันที่ 28 พฤศจิกายน 2019 ) แนะนำฟังก์ชันที่ไม่ระบุตัวตนที่สั้นกว่าซึ่งเรียกว่าฟังก์ชันลูกศรซึ่งทำให้รายละเอียดน้อยลงเล็กน้อย

ตัวอย่างการใช้ PHP 7.4 ซึ่งทำงานได้เกือบเทียบเท่า (ดูสัญลักษณ์แสดงหัวข้อย่อยที่ 3 ด้านล่าง):

DB::table('users')->where(fn($query) => $query->where('activated', '=', $activated))->get();

ความแตกต่างเมื่อเทียบกับไวยากรณ์ปกติ:

  • fnคีย์เวิร์ดแทนfunction.
  • ไม่จำเป็นต้องแสดงรายการตัวแปรทั้งหมดอย่างชัดเจนซึ่งควรถูกจับจากขอบเขตหลัก - ตอนนี้ทำโดยอัตโนมัติตามค่า ดูการขาดuseคีย์เวิร์ดในตัวอย่างหลัง
  • ฟังก์ชันลูกศรจะส่งคืนค่าเสมอ นอกจากนี้ยังหมายความว่าไม่สามารถใช้voidreturn type เมื่อประกาศได้
  • returnคำหลักที่จะต้องถูกมองข้าม
  • ฟังก์ชันลูกศรต้องมีนิพจน์เดียวซึ่งเป็นคำสั่งส่งคืน ไม่รองรับฟังก์ชันหลายบรรทัดในขณะนี้ คุณยังสามารถใช้วิธีการเชื่อมโยงได้

15

คำตอบของ @kajetons ใช้งานได้เต็มที่

นอกจากนี้คุณยังสามารถส่งผ่านตัวแปรได้หลายตัวโดยส่งผ่านเช่น: use($var1, $var2)

DB::table('users')->where(function ($query) use ($activated,$var2) {
    $query->where('activated', '=', $activated);
    $query->where('var2', '>', $var2);
})->get();

5

หากคุณใช้ Laravel eloquent คุณอาจลองใช้สิ่งนี้ได้เช่นกัน

$result = self::select('*')
                    ->with('user')
                    ->where('subscriptionPlan', function($query) use($activated){
                        $query->where('activated', '=', $roleId);
                    })
                    ->get();

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.