gpt4 book ai didi

php activerecord 多对多

转载 作者:行者123 更新时间:2023-12-02 05:11:50 24 4
gpt4 key购买 nike

我有三个模型:

// student_id student_name
Student extends ActiveRecord\Model
{
static $has_many = array(
array('studentcourses')
);
}

// course_id course_name
Course extends ActiveRecord\Model
{
static $has_many = array(
array('students')
);
}

// course_id student_id
Studentcourse extends ActiveRecord\Model
{
static $belongs_to = array(
array('student')
);
}

因此,通过这样做,我将能够轻松地从这些表中检索数据:

$student = Student::find(1);

foreach ($student->studentcourses as $course)
{
echo $course->name;
}

但我不想输入“studentcourses”,而是想输入 $student->courses 来获取学生就读的所有类(class),输入 $course->students 来获取特定类(class)的学生列表。关系设置将如何实现?

最佳答案

我认为您需要的是多对多关系。要在 PHP-AR 中设置它:

// student_id student_name
Class Student extends ActiveRecord\Model
{
static $has_many = array(
array('courses', 'through' => 'studentcourses'),
array('studentcourses')
);
}

// course_id course_name
Class Course extends ActiveRecord\Model
{
static $has_many = array(
array('students', 'through' => 'studentcourses'),
array('studentcourses')
);
}

// course_id student_id
Class Studentcourse extends ActiveRecord\Model
{
static $belongs_to = array(
array('student'),
array('course')
);
}

不要忘记 studentcourses 表必须包含:id(主键)、student_idcourse_id .

关于php activerecord 多对多,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15309095/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com