laravel 模型多对多,应用

laravel 模型多对多,应用,试卷 跟 区域 多对多关系

一个试卷可以发放到a b c 区域
  1. 创建试卷表

    CREATE TABLE exams (
    exam_id int(11) unsigned NOT NULL AUTO_INCREMENT,
    exam_title varchar(100) NOT NULL DEFAULT '' COMMENT '标题',
    created_time int(11) NOT NULL DEFAULT '0',
    updated_time int(11) NOT NULL,
    PRIMARY KEY (exam_id) USING BTREE

  2. 创建区域表

    CREATE TABLE area (
    area_id int(11) unsigned NOT NULL AUTO_INCREMENT,
    area_name varchar(100) NOT NULL DEFAULT '' COMMENT '标题',
    parent_id int(10) NOT NULL DEFAULT '0' COMMENT '父级ID\n',
    created_time int(11) NOT NULL DEFAULT '0',
    updated_time int(11) NOT NULL DEFAULT '0',
    PRIMARY KEY (area_id) USING BTREE
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 ROW_FORMAT=DYNAMIC;

  3. 创建区域跟试卷表的多对多关系表

    CREATE TABLE zt_exam_id_with_area_id (
    with_id bigint(20) unsigned NOT NULL AUTO_INCREMENT,
    exam_id int(10) unsigned NOT NULL DEFAULT '0' COMMENT '试卷id',
    area_id int(10) unsigned NOT NULL DEFAULT '0' COMMENT '区域id',
    PRIMARY KEY (with_id) USING BTREE,
    KEY exam_id_with_area_id_index (exam_id) USING BTREE
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci ROW_FORMAT=DYNAMIC COMMENT='试卷跟区域关联关系,多对多';

  4. exams 模型 简历 跟 area 多对多的关系

     public function areaIds()
     {
    
         $DB_PREFIX = env('DB_PREFIX');
         return $this->belongsToMany(Area::class, 'exam_id_with_area_id', 'exam_id', 'area_id')
             ->select(DB::raw("DISTINCT({$DB_PREFIX}area.`area_id`),`{$DB_PREFIX}area`.*"));
     }
    

. 1.通过中间表:exam_id_with_area_id 建立 试卷 跟 区域的多对多关系

  1. 调用 exam模型的对对多方法

    $model = new exams模型()
    primary_key = "exams模型表自增主键 对应的值 如:1"
    $detail = model->find(primary_key)
    $detail->areaIds->toArray();
    返回试卷为1:对应可以发放的试卷信息列表

$detail->areaIds->toArray(); 转为 具体的 demo sql:

 select * from area  as a inner join exam_id_with_area_id  wi on a.area_id=wi.area_id where exam_id=1
相关推荐
计算机专业源码2 天前
Thinkphp/Laravel基于vue的的出版社书籍阅读管理系统
vue.js·php·laravel
一个人的程序2 天前
laravel 开发youtube项目1-登录注册
后端·laravel
小雨cc5566ru4 天前
Thinkphp/Laravel基于vue的实验室上机管理系统
android·vue.js·laravel
小雨cc5566ru6 天前
Thinkphp/Laravel基于Vue的重庆旅游网站交互设计与实现
vue.js·laravel·旅游
程序员小猪。17 天前
laravel public 目录获取
laravel·public·public目录
兜兜 里 有糖24 天前
laravel 查询数据对象转数组
android·java·laravel
程序员小猪。1 个月前
laravel请求第三方接口
http·laravel
bobo-rs1 个月前
Laravel 中间件与事件应用教程
中间件·php·laravel·事件·events
Xerale1 个月前
实现微信公众号的生成二维码,二维码和图片合并
前端·笔记·微信·php·laravel
老A技术联盟1 个月前
从并发20到并发120之laravel性能优化
php·laravel