การเข้าร่วมหลายครั้งใน Eloquent จากขอบเขตท้องถิ่น
Aug 16 2020
มีคำถามเกี่ยวกับ Eloquent และฟังก์ชันขอบเขต:
สมมติว่าสองขอบเขต:
class Result extends Model {
public function scopeIsRace($query) { return $query
->join('sessions', 'sessions.id', '=', 'results.session_id')
->where('sessions.type', 10)
}
public function scopeIsOfficial($query) { return $query
->join('sessions', 'sessions.id', '=', 'results.session_id')
->join('events', 'events.id', '=', 'sessions.event_id')
->where('events.regular_event', 1);
}
}
การเรียกทั้งคู่จะทำการรวมเซสชันสองครั้งและแบบสอบถามผลลัพธ์จะมีลักษณะเช่นนี้ (ไม่ได้ผล)
select * from `results` inner join `sessions` on `sessions`.`id` = `results`.`session_id` inner join `sessions` on `sessions`.`id` = `results`.`session_id` inner join `events` on `events`.`id` = `sessions`.`event_id` where `driver_id` = 24 and (`sessions`.`type` = 10 or `sessions`.`type` = 11) and `events`.`regular_event` = 1
ฉันจะป้องกันการเข้าร่วมสองครั้งในเซสชันได้อย่างไร
คำตอบ
1 Siggi Aug 16 2020 at 15:51
ขอบคุณมาก @Nima. ลืมเรื่องขั้นสูงไปโดยสิ้นเชิง ใช้โครงสร้างจากคำถามที่คุณแนะนำและทำงานได้ดีอย่างสมบูรณ์:
public function scopeIsRace($query) { return $query->whereHas('session', function($query){ $query->where('type', 10);
});
}
public function scopeIsOfficial($query) { return $query->whereHas('session', function($query) { return $query->whereHas('event', function($query2) { $query2->where('regular_event', 1);
});
});
}