当前位置: 首页 > news >正文

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
  1. 创建区域表
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;
  1. 创建区域跟试卷表的多对多关系表
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='试卷跟区域关联关系,多对多';
  1. 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

相关文章:

laravel 模型多对多,应用

laravel 模型多对多,应用,试卷 跟 区域 多对多关系 一个试卷可以发放到a b c 区域 创建试卷表 CREATE TABLE exams (exam_id int(11) unsigned NOT NULL AUTO_INCREMENT,exam_title varchar(100) NOT NULL DEFAULT COMMENT 标题,created_time int(11…...

嵌入式学习35-网络通信UDP聊天及TCP

题目:基于UDP实现直播间聊天的功能 需求: 软件划分为用户客户端和主播服务端两个软件client.c和server.c 用户客户端负责: 1.接收用户的昵称 2.接收用户输入的信息,能够将信息发送给服务端 3.接收服…...

Python:if条件判断语句

注意&#xff1a;本文引用自专业人工智能社区Venus AI 更多AI知识请参考原站 &#xff08;[www.aideeplearning.cn]&#xff09; 内容简介 比较运算符和关系运算符&#xff1a; 本文将介绍Python中常见的比较运算符&#xff0c;如 &#xff08;等于&#xff09;、! 和 <&…...

git 命令怎么回退到某个特定的 commit 并将其推送到远程仓库?

问题 不小心把提交的名称写错提交上远程仓库了&#xff0c;这里应该是 【029】的&#xff0c;这个时候我们想回到【028】这一个提交记录&#xff0c;然后再重新提交【029】到远程仓库&#xff0c;该怎么处理。 解决 1、首先我们找到【028】这条记录的提交 hash&#xff0c;右…...

Python中如何操作数据库?

Python中如何操作数据库&#xff1f; ​​​​​ 在Python中操作数据库通常涉及到使用数据库驱动程序或ORM&#xff08;对象关系映射&#xff09;库。下面是一些常见的步骤和工具&#xff0c;用于在Python中操作数据库&#xff1a; 1. 选择数据库和驱动程序 首先&#xff0c…...

【智能算法】蜻蜓算法(DA)原理及实现

目录 1.背景2.算法原理2.1算法思想2.2算法过程 3.代码实现4.参考文献 1.背景 2016年&#xff0c;Mirjalili受到蜻蜓静态和动态集群行为启发&#xff0c;提出了蜻蜓算法(Dragonfly algorithm, DA)。 2.算法原理 2.1算法思想 蜻蜓集群有两种行为目的&#xff1a;狩猎&#xf…...

用A*算法求解八数码问题

用A*算法求解八数码问题 实现两种启发函数实现A*算法测试 实现两种启发函数 采取两种策略实现启发函数&#xff1a; 策略1&#xff1a;不在目标位置的数字个数策略2&#xff1a;曼哈顿距离&#xff08;将数字直接移动到对应位置的步数总数&#xff09; # 策略1: 不在目标位置…...

分布式之Ribbon使用以及原理

Ribbon使用以及原理 1、负载均衡的两种方式 服务器端负载均衡 传统的方式前端发送请求会到我们的的nginx上去&#xff0c;nginx作为反向代理&#xff0c;然后路由给后端的服务器&#xff0c;由于负载均衡算法是nginx提供的&#xff0c;而nginx是部署到服务器端的&#xff0c;所…...

android JNI float *转MutableList

data class Test(var data:MutableList<Float> )JNIEXPORT void JNICALL Java_NativeUtils_assignFloatArrayToHealth(JNIEnv *env, jclass clazz, jobject obj, jfloatArray cData) {jclass objClass env->GetObjectClass(obj);// 获取 Test类中的 data 属性jfieldI…...

chatgpt与人类有何不同?

ChatGPT和人类之间存在多个显著的差异。 首先&#xff0c;ChatGPT是一种基于人工智能技术的计算机程序&#xff0c;通过机器学习和自然语言处理等技术&#xff0c;从大量的数据中获取知识并生成语言输出。它主要依赖于算法和数据进行工作&#xff0c;能够迅速处理和检索信息&a…...

论文笔记:Evaluating the Performance of Large Language Models on GAOKAO Benchmark

1 论文思路 采用zero-shot prompting的方式&#xff0c;将试题转化为ChatGPT的输入 对于数学题&#xff0c;将公式转化为latex输入 主观题由专业教师打分 2 数据 2010~2022年&#xff0c;一共13年间的全国A卷和全国B卷 3 结论 3.1 不同模型的zeroshot 高考总分 3.2 各科主…...

MySQL 数据库查询与数据操作:使用 ORDER BY 排序和 DELETE 删除记录

使用 ORDER BY 进行排序 使用 ORDER BY 语句按升序或降序对结果进行排序。 ORDER BY 关键字默认按升序排序。要按降序排序结果&#xff0c;使用 DESC 关键字。 示例按名称按字母顺序排序结果&#xff1a; import mysql.connectormydb mysql.connector.connect(host"l…...

数据结构入门(3)2.链表接口实现

目录 前言 头文件 动态申请一个结点 单链表打印 单链表尾插 单链表的头插 单链表的尾删 单链表头删 单链表查找 单链表在pos位置之后插入x 单链表删除pos位置之后的值 在pos的前面插入 删除pos位置 销毁顺序表 前言 本文将介绍链表常见的功能的实现 头文件 #…...

vscode中解决驱动编写的时候static int __init chrdev_init()报错的问题

目录 错误出错原因解决方法 错误 在入口函数上&#xff0c;出现 expected a ; 这样的提示 出错原因 缺少了 __KERNEL __ 宏定义 解决方法 补上__KERNEL__宏定义 具体做法&#xff1a;在vscode中按下ctrlshiftp &#xff0c;输入&#xff1a;C/C:Edit Configurations&#xff0…...

fastgpt本地详细部署以及配置

目录 一、Docker部署1、docker安装2、docker启动3、添加用户到 docker 组:4、验证 Docker 安装:二、one_api 本地部署1、linux系统部署2、windows系统部署三、向量模型部署(m3e)四、chatglm2模型本地部署五、fastgpt模型本地部署1、下载配置文件2、文件配置--docker-compos…...

【故障分类】基于注意力机制的卷积神经网络结合双向长短记忆神经网络CNN-BiLSTM-attention实现数据分类附matlab代码

摘要&#xff1a; ntion机制加权 4. 加权后的特征进行分类 需求分析 本文旨在实现一个通用的数据分类模型&#xff0c;可应用于不同领域的数据分类任务。 设计方案 设计一个CNN网络结构&#xff0c;提取输入数据的特征 将特征序列输入到BiLSTM网络&#xff0c;进行时序建模…...

vue接入百度地图获取经纬度

通过城市名称和城市中心经纬度来获取当前所在地图&#xff0c;当前经纬度中心获取可以通过后端获取 静态文件包&#xff0c;替换baidu.html中的ak值&#xff0c;ak值通过百度地图官方网站申请 申请&#xff1a;百度地图API申请步骤 - 知乎 代码示例文件&#xff1a; 链接&a…...

交流负载箱的特点和优势有哪些?

交流负载箱广泛应用于电力系统、新能源、轨道交通、航空航天等领域。它具有以下特点和优势&#xff1a; 1. 灵活性高&#xff1a;交流负载箱可以根据实际需求&#xff0c;调整输出电流、电压、功率等参数&#xff0c;以满足不同场景下的测试需求。同时&#xff0c;它还可以实现…...

Java线程锁之Lock的使用

Lock 的使用 Lock 是java 1.5 中引入的线程同步工具&#xff0c;它主要用于多线程下共享资源的控制。本质上Lock 仅仅是一个接口&#xff0c; 可以通过显式定义同步锁对象来实现同步&#xff0c;能够提供比synchronized 更广泛的锁定操作&#xff0c;并支持多个相关的 Lock接…...

简站wordpress主题看上去差不多 实际大不一样

有人说简站wordpress主题&#xff0c;都差不多嘛。我表示无语。表面看上去是差不多的&#xff0c;实际的细节是不一样的。 下面以编号&#xff1a;JZP4431和编号&#xff1a;JZP4878这两个主题为例子来讲一下&#xff0c;简站wordpress主题&#xff0c;在细节方面的不一样之处…...

软考高项·信息系统项目管理师 备考攻略(作文专题)

作者经历&#xff1a;改机考后第一年通过。第一次考试仅通过选择题&#xff1b;第二次考试作文未通过&#xff1b;第三次考试&#xff08;机考&#xff09;作文顺利通过&#xff0c;三科全过。欢迎关注, 后续会逐步推出更多备考攻略一、我的三次考试经历 第一次考试&#xff1a…...

告别网盘限速!八大平台直链解析工具终极指南

告别网盘限速&#xff01;八大平台直链解析工具终极指南 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 &#xff0c;支持 百度网盘 / 阿里云盘 / 中国移动云盘 / 天翼云盘 / 迅…...

从Bash迁移到Zsh:Oh My Zsh实战避坑指南(含性能对比)

从Bash迁移到Zsh&#xff1a;Oh My Zsh实战避坑指南&#xff08;含性能对比&#xff09; 如果你长期使用Bash&#xff0c;可能会对Zsh的流畅补全和主题系统产生好奇。但迁移不只是换个Shell那么简单——环境变量继承、脚本兼容性和性能差异都可能成为隐形陷阱。本文将用实测数据…...

塑胶产品结构设计查询软件

塑胶产品结构设计核心要点速查指南&#xff08;基于“紫垣商驿 v3.2”软件内容整理&#xff09;本指南提炼了塑胶产品结构设计中关于胶厚、加强筋、孔的三个最关键模块的设计规范&#xff0c;旨在帮助工程师快速掌握核心原则&#xff0c;避免常见缺陷。第一章&#xff1a;胶厚&…...

5分钟解锁B站缓存视频:m4s-converter让你的收藏永不消失

5分钟解锁B站缓存视频&#xff1a;m4s-converter让你的收藏永不消失 【免费下载链接】m4s-converter 一个跨平台小工具&#xff0c;将bilibili缓存的m4s格式音视频文件合并成mp4 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 你是否曾有过这样的经历&…...

【R 4.5大数据处理性能跃迁指南】:20年实战验证的7大底层优化策略(含benchmark实测提升3.8×)

第一章&#xff1a;R 4.5大数据处理性能跃迁的核心动因与基准定位R 4.5 版本在底层内存管理、向量化执行引擎及并行调度机制上实现了结构性升级&#xff0c;显著提升了大规模数据集&#xff08;GB级及以上&#xff09;的加载、聚合与建模效率。其核心动因并非单一优化&#xff…...

别再手动复制SSH公钥了,Linux服务器一键从GitHub快速导入公钥捕

一、项目背景与核心价值 1. 解决的核心痛点 Navicat的数据库连接密码并非明文存储&#xff0c;而是通过AES算法加密后写入.ncx格式的XML配置文件中。一旦用户忘记密码&#xff0c;常规方式只能重新配置连接&#xff0c;效率极低。本项目只作为学习研究使用&#xff0c;不做其他…...

LaTeX公式一键转换Word:告别复制粘贴的终极解决方案

LaTeX公式一键转换Word&#xff1a;告别复制粘贴的终极解决方案 【免费下载链接】LaTeX2Word-Equation Copy LaTeX Equations as Word Equations, a Chrome Extension 项目地址: https://gitcode.com/gh_mirrors/la/LaTeX2Word-Equation 还在为学术论文中的公式迁移而烦…...

在Windows 10/11上部署ArcGIS 10.2开发环境:ArcEngine SDK for .NET配置详解

在Windows 10/11上构建ArcGIS 10.2开发环境&#xff1a;从零开始打造GIS应用 当你第一次尝试在Visual Studio中调用ArcEngine的类库时&#xff0c;是否遇到过令人抓狂的"未找到引用"错误&#xff1f;或是明明按照教程一步步操作&#xff0c;却在运行时遭遇神秘的许可…...

【2026年最新600套毕设项目分享】基于微信小程序的童装商城(30023)

有需要的同学&#xff0c;源代码和配套文档领取&#xff0c;加文章最下方的名片哦 一、项目演示 项目演示视频 二、资料介绍 完整源代码&#xff08;前后端源代码SQL脚本&#xff09;配套文档&#xff08;LWPPT开题报告/任务书&#xff09;远程调试控屏包运行一键启动项目&…...