电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Laravel?Many-To-Many多對多關系模式示例詳解

瀏覽:17日期:2022-06-13 18:55:32
目錄常見的對應關系模式1. 創建數據庫表2. 創建模型并指定關系3. 在Controller中使用常見的對應關系模式

在實際的開發中,我們經常會接觸到幾種常見的對應關系模式:

One-To-One //一對一One-To-Many //一對多Many-To-Many //多對多

在剛剛開始接觸到這些概念的時候,其實我是不太理解的。但是一旦你將這些概念應用到生活中,理解起來就很簡單了,就舉一個與我們在網上經常見到的例子:

User-To-Profile // One-To-OneUser-To-Articles // One-To-ManyArticles-To-Tags // Many-To-Many

翻譯過來就是:

一個用戶對應一個用戶檔案一個用戶可以發表多篇文章而文章和標簽確實多對多的關系,一篇文章可以有多個標簽;一個標簽可以屬于多篇文章

在這些關系模型中,最難實現的就是Many-To-Many這種多對多的關系,不過借助Laravel的強大的Eloquent,實現這個功能還是比較順心的。

1. 創建數據庫表

創建articles表

Schema::create('articles', function (Blueprint $table) { $table->increments('id'); $table->string('title'); $table->text('content'); $table->timestamps();});

創建tags表

Schema::create('tags', function (Blueprint $table) { $table->increments('id'); $table->string('name'); $table->timestamps();});

當然,解決這個經典問題單單靠這兩張表還不足夠,需要在這兩張表之外再建立一個關系表,用來將article和tag聯系起來,在Laravel中,如果你遵循官方的標準規則,第三張表應該是這樣的:

表名 article_tag

Schema::create('article_tag', function(Blueprint $table) { $table->integer('article_id')->unsigned()->index(); $table->foreign('article_id')->references('id')->on('articles')->onDelete('cascade'); $table->integer('tag_id')->unsigned()->index(); $table->foreign('tag_id')->references('id')->on('tags')->onDelete('cascade');});

如果你沒有按照官方的規范來,你需要在模型中指定外鍵。

2. 創建模型并指定關系

在Article.php中:

public function tags() {return $this->belongsToMany('App\Tag'); }

在Tag.php中:

public function articles() {return $this->belongsToMany('App\Article'); }

這里注意兩點:

你可以在聲明關系的時候指定外鍵,如$this->belongsToMany('App\Article','foreign_key', 'other_key');如果在article_tag表中你添加了timestamps(),即表中出現created_at和updated_at這兩個字段,在Article中聲明關系的時候需要這樣:return $this->belongsToMany('App\Tag')->withTimestamps();3. 在Controller中使用

如果我們想查看某個文章含有哪些標簽,我們可以這樣:

$article = Article::find($id);dd($article->tags);

如果我們想通過某個標簽來查找文章:

public function showArticleByTagName($name) {$tag = Tag::where('value','=',$name)->first();dd($tag->articles); }

以上,就實現了在Laravel中的Many-To-Many,更多關于Laravel 多對多關系模式的資料請關注好吧啦網其它相關文章!

標簽: PHP
主站蜘蛛池模板: 新中天检测有限公司青岛分公司-山东|菏泽|济南|潍坊|泰安防雷检测验收 | 拉力机-万能试验机-材料拉伸试验机-电子拉力机-拉力试验机厂家-冲击试验机-苏州皖仪实验仪器有限公司 | 精准猎取科技资讯,高效阅读科技新闻_科技猎 | 武汉高低温试验机-现货恒温恒湿试验箱-高低温湿热交变箱价格-湖北高天试验设备 | 搪玻璃冷凝器_厂家-越宏化工设备 | 空压机商城|空气压缩机|空压机配件-压缩机网旗下商城 | 粘度计,数显粘度计,指针旋转粘度计| 模温机-油温机-电加热导热油炉-工业冷水机「欧诺智能」 | 手术室净化厂家_成都实验室装修公司_无尘车间施工单位_洁净室工程建设团队-四川华锐16年行业经验 | 铸钢件厂家-铸钢齿轮-减速机厂家-淄博凯振机械有限公司 | 2025福建平潭岛旅游攻略|蓝眼泪,景点,住宿攻略-趣平潭网 | [官网]叛逆孩子管教_戒网瘾学校_全封闭问题青少年素质教育_新起点青少年特训学校 | 防渗膜厂家|养殖防渗膜|水产养殖防渗膜-泰安佳路通工程材料有限公司 | 氢氧化钙设备_厂家-淄博工贸有限公司 | 太阳能发电系统-太阳能逆变器,控制器-河北沐天太阳能科技首页 | 临朐空调移机_空调维修「空调回收」临朐二手空调 | 国际船舶网 - 船厂、船舶、造船、船舶设备、航运及海洋工程等相关行业综合信息平台 | 网站建设-临朐爱采购-抖音运营-山东兆通网络科技 | 膏剂灌装旋盖机-眼药水灌装生产线-西林瓶粉剂分装机-南通博琅机械科技 | 润滑脂-高温润滑脂-轴承润滑脂-食品级润滑油-索科润滑油脂厂家 | 多功能三相相位伏安表-变压器短路阻抗测试仪-上海妙定电气 | 贵州自考_贵州自学考试网| Magnescale探规,Magnescale磁栅尺,Magnescale传感器,Magnescale测厚仪,Mitutoyo光栅尺,笔式位移传感器-苏州连达精密量仪有限公司 | 二手色谱仪器,十万分之一分析天平,蒸发光检测器,电位滴定仪-湖北捷岛科学仪器有限公司 | 破碎机锤头_耐磨锤头_合金锤头-鼎成机械一站式耐磨铸件定制服务 微型驱动系统解决方案-深圳市兆威机电股份有限公司 | 上海盐水喷雾试验机_两厢式冷热冲击试验箱-巨怡环试 | 昆山新莱洁净应用材料股份有限公司-卫生级蝶阀,无菌取样阀,不锈钢隔膜阀,换向阀,离心泵 | 电车线(用于供电给电车的输电线路)-百科 | 密度电子天平-内校-外校电子天平-沈阳龙腾电子有限公司 | GAST/BRIWATEC/CINCINNATI/KARL-KLEIN/ZIEHL-ABEGG风机|亚喜科技 | ERP企业管理系统永久免费版_在线ERP系统_OA办公_云版软件官网 | 重庆LED显示屏_显示屏安装公司_重庆LED显示屏批发-彩光科技公司 重庆钣金加工厂家首页-专业定做监控电视墙_操作台 | 密集架|电动密集架|移动密集架|黑龙江档案密集架-大量现货厂家销售 | 滚珠丝杆升降机_螺旋升降机_丝杠升降机-德迈传动 | 成都热收缩包装机_袖口式膜包机_高速塑封机价格_全自动封切机器_大型套膜机厂家 | 河南不锈钢水箱_地埋水箱_镀锌板水箱_消防水箱厂家-河南联固供水设备有限公司 | 舞台木地板厂家_体育运动木地板_室内篮球馆木地板_实木运动地板厂家_欧氏篮球地板推荐 | 陕西鹏展科技有限公司| 铁盒_铁罐_马口铁盒_马口铁罐_铁盒生产厂家-广州博新制罐 | 全自动实验室洗瓶机,移液管|培养皿|进样瓶清洗机,清洗剂-广州摩特伟希尔机械设备有限责任公司 | 广东青藤环境科技有限公司-水质检测 |