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
相关推荐
凯新生物1 天前
聚乙二醇二生物素,Biotin-PEG-Biotin在生物检测中的应用
scala·bash·laravel·perl
catchadmin2 天前
Laravel + Vue3 前后端分离开源后台管理框架 CatchAdmin v5.0 Beta 发布
php·laravel
pandarking3 天前
[CTF]攻防世界:easy_laravel 学习
java·学习·web安全·laravel·ctf
catchadmin5 天前
告别 Shell 脚本:用 Laravel Envoy 实现干净可复用的部署
php·laravel
JienDa6 天前
JienDa聊PHP:从Laravel到ThinkPHP的现代Web开发实践
前端·php·laravel
catchadmin7 天前
用 Laravel 官方 AI 工具提升开发效率 效率提示数倍
人工智能·php·laravel
JaguarJack8 天前
用 Laravel 官方 AI 工具提升开发效率
php·laravel·服务端
tg-zm88999617 天前
2025返利商城源码/挂机自动收益可二开多语言/自定义返利比例/三级分销理财商城
java·mysql·php·laravel·1024程序员节
luminaryhero17 天前
Laravel学习-01预备阶段-05 命令行
laravel
luminaryhero17 天前
Laravel学习-01预备阶段-02 Composer
laravel