多对多关联更为复杂。
中间表:php artisan make:model Models/GradeStudent -m
data:image/s3,"s3://crabby-images/5fdfb/5fdfbd89745e9d54fb80b0656bed479f18dd2bde" alt="1561519902349719.png image.png"
课程表:php artisan make:migration create_grade
php artisan make:model Models/Grade -m
data:image/s3,"s3://crabby-images/6ce2a/6ce2af5c9f85cf94dc2fba674b2051f2e45b2968" alt="1561519910638243.png image.png"
学生表:php artisan make:migration create_student
php artisan make:model Models/Student -m
data:image/s3,"s3://crabby-images/0a2a6/0a2a616125df04645cdcc1f57f7ec2d4d6a7fe66" alt="1561519915790979.png image.png"
belongsToMany('关联模型','中间表','外键','关联键');
关联模型(必须):模型名或者模型类名
中间表:默认规则是当前模型名+_+关联模型名 (可以指定模型名)
外键 :中间表的当前模型外键,默认的外键名规则是关联模型名+_id
关联键:中间表的关联模型关联键名,默认规则是关联模型名+_id
在student模型中:
通过中间表 gradestatus找到关联表grade
Public function grade(){
1.要关联的表 2,中间表3 当前模型在中间表外键 4,要关联的模型在中间表的外键
Return$this->belongstomany(‘grade::class’,’grade_students’,’student_id’ ,’grade_id’);
}
定义关联关系:注意这里我们直接使用了中间表的方式
data:image/s3,"s3://crabby-images/f6ccb/f6ccb918d00bc5239aff91f59a1fff4abb68c275" alt="1561519921398724.png image.png"
data:image/s3,"s3://crabby-images/1ec37/1ec3707295d0e7160d47d2e0c0e8d95d45d0ce61" alt="1561519925836078.png image.png"