ThinkPHP 8的一對多關聯

【圖書介紹】《ThinkPHP 8高效構建Web應用》-CSDN博客

《2025新書 ThinkPHP 8高效構建Web應用 編程與應用開發叢書 夏磊 清華大學出版社教材書籍 9787302678236 ThinkPHP 8高效構建Web應用》【摘要 書評 試讀】- 京東圖書

使用VS Code開發ThinkPHP項目-CSDN博客

編程與應用開發_夏天又到了的博客-CSDN博客

每個主模型都有多個關聯模型,一般在關聯模型添加一個外鍵實現,在模型中使用hasMany定義。下面是用戶和地址的一對多關聯示例。首先在mydb數據庫中創建address表及其數據(表比較簡單,我們賦予這表一個意義,即保存用戶游玩過的省份。建議讀者直接用MySQL Workbench工具快速完成),SQL語句如下:

CREATE TABLE `address` (`aid` int NOT NULL AUTO_INCREMENT,`id` int NOT NULL,`province` varchar(45) COLLATE utf8mb3_unicode_ci NOT NULL,PRIMARY KEY (`aid`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3;
INSERT INTO `mydb`.`address`(`aid`,`id`,`province`) VALUES(1,1, '北京' );
INSERT INTO `mydb`.`address`(`aid`,`id`,`province`) VALUES(2,1, '上海' );
INSERT INTO `mydb`.`address`(`aid`,`id`,`province`) VALUES(3,1, '廣東' );

1. 用戶模型

用戶模型示例如下:

<?php
namespace app\model;use think\Model;class UserModel extends Model
{protected $table = 'users';// 設置字段信息protected $schema = ['id'          => 'int','name'        => 'string','nickname'      => 'string','status' => 'int',];public function profile(){return $this->hasOne(ProfileModel::class,'id'); // hasOne}// 在一對一關聯示例代碼的基礎上,再加一個一對多關聯方法public function addresses(){return $this->hasMany(AddressModel::class, 'id'); // hasMany}
}

2. 地址模型

地址模型示例如下:

<?php
namespace app\model;use think\Model;class AddressModel extends Model
{   protected $table = 'address';// 設置字段信息protected $schema = ['aid'		=> 'int','id'			=> 'int','province'	=> 'string',];
}

3. 關聯查詢

由于只有同一個數據庫的數據表可以與表相連,因此在分庫分表的場景下,筆者建議使用with查詢兩次的方法。

<?php
namespace app\controller;use think\Model;
use app\model\UserModel;
use app\model\ProfileModel;class User {public function one2many(){$users = UserModel::with('addresses')->select();foreach ($users as $user) {foreach($user->addresses as $address) {print_r($user->name.',  '. $address->province.'<br>');}}}
}

上面2個模型1個控制器完成后,運行服務器,在瀏覽器中訪問http://localthost:8000/user/one2many,可以關聯查詢出id為1的用戶所有游玩過的省份。

4. 關聯保存

使用關聯模型的saveAll方法保存關聯數據。下面是批量保存地址的示例:

$user = UserModel::find(2);
$user->addresses()->saveAll([['province'=>'北京'],['province'=>'上海'],
]);

5. 關聯刪除

和一對一關聯相同,一對多關聯也使用together方法刪除關聯數據。示例如下:

$user->together(['addresses'])->delete();

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/66353.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/66353.shtml
英文地址,請注明出處:http://en.pswp.cn/web/66353.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

工業網口相機:如何通過調整網口參數設置,優化圖像傳輸和網絡性能,達到最大幀率

項目場景 工業相機是常用與工業視覺領域的常用專業視覺核心部件&#xff0c;擁有多種屬性&#xff0c;是機器視覺系統中的核心部件&#xff0c;具有不可替代的重要功能。 工業相機已經被廣泛應用于工業生產線在線檢測、智能交通,機器視覺,科研,軍事科學,航天航空等眾多領域 …

java使用poi-tl自定義word模板導出

文章目錄 概要整體架構流程創建word模板核心代碼導出結果 概要 在軟件開發領域&#xff0c;自定義Word模板的使用是導出格式化數據的一種常見做法。poi-tl&#xff08;Apache POI Template Language&#xff09;作為一款基于廣受認可的Apache POI庫的Word模板引擎&#xff0c;…

IDEA2023版中TODO的使用

介紹&#xff1a;TODO其實本質上還是注釋&#xff0c;只不過加上了TODO這幾個字符&#xff0c;可以讓使用者快速找到。 注意&#xff1a;在類、接口等文件中&#xff0c;注釋是使用// 即&#xff1a;// TODO 注釋內容 在配置文件中&#xff0c;注釋是使用# 即&#xff1a;# TO…

項目練習:若依管理系統字典功能-Vue前端部分

文章目錄 一、情景說明二、若依Vue相關代碼及配置1、utils代碼2、components組件3、api接口代碼4、Vuex配置5、main.js配置 三、使用方法1、html部分2、js部分 一、情景說明 我們在做web系統的時候&#xff0c;肯定會遇到一些常量選擇場景。 比如&#xff0c;性別&#xff1a;…

LabVIEW開發X光圖像的邊緣檢測

在醫療影像處理中&#xff0c;X光圖像的分析對于骨折、腫瘤等病變的檢測非常重要。X光圖像中包含許多關鍵信息&#xff0c;然而&#xff0c;由于圖像噪聲的干擾&#xff0c;直接從圖像中提取有用的特征&#xff08;如骨折的邊緣&#xff09;變得非常困難。邊緣檢測作為圖像處理…

【CC2640R2F】香瓜CC2640R2F之SPI讀寫W25Q80

本文最后修改時間&#xff1a;2022年01月08日 10:45 一、本節簡介 本節以simple_peripheral工程為例&#xff0c;介紹如何使用SPI讀寫W25Q80&#xff08;外部flash&#xff09;。 二、實驗平臺 1&#xff09;CC2640R2F平臺 ①協議棧版本&#xff1a;CC2640R2 SDK v1.40.00.4…

光譜相機如何還原色彩

多光譜通道采集 光譜相機設有多個不同波段的光譜通道&#xff0c;可精確記錄每個波長的光強信息。如 8 到 16 個甚至更多的光譜通道&#xff0c;每個通道負責特定波長范圍的光信息記錄。這使得相機能分辨出不同光譜組合產生的相同顏色感知&#xff0c;而傳統相機的傳感器通常只…

C# 獲取PDF文檔中的字體信息(字體名、大小、顏色、樣式等

在設計和出版行業中&#xff0c;字體的選擇和使用對最終作品的質量有著重要影響。然而&#xff0c;有時我們可能會遇到包含未知字體的PDF文件&#xff0c;這使得我們無法準確地復制或修改文檔。獲取PDF中的字體信息可以解決這個問題&#xff0c;讓我們能夠更好地處理這些文件。…

C++ 的 CTAD 與推斷指示(Deduction Guides)

1 類模板參數推導&#xff08;CTAD&#xff09; 1.1 曲線救國 ? CTAD 的全稱是類模板參數推導&#xff08;Class Template Argument Deduction&#xff09;&#xff0c;它允許在實例化類模板時&#xff0c;根據構造函數的參數類型自動推導模板參數&#xff0c;從而避免顯式指…

Shell正則表達式與文本處理三劍客(grep、sed、awk)

一、正則表達式 Shell正則表達式分為兩種&#xff1a; 基礎正則表達式&#xff1a;BRE&#xff08;basic regular express&#xff09; 擴展正則表達式&#xff1a;ERE&#xff08;extend regular express&#xff09;&#xff0c;擴展的表達式有、?、|和() 1.1 基本正則表…

掌握 React 高階組件與高階函數:構建可復用組件的新境界

一、引言 在 React 開發中&#xff0c;代碼復用性和邏輯分離是提高開發效率和維護性的重要手段。高階組件&#xff08;Higher-Order Component, HOC&#xff09;和高階函數&#xff08;Higher-Order Function, HOF&#xff09;是實現這一目標的兩種強大工具。本文將詳細介紹這…

arcgis提取不規則柵格數據的矢量邊界

效果 1、準備數據 柵格數據:dem或者dsm 2、柵格重分類 分成兩類即可 3、新建線面圖層 在目錄下選擇預先準備好的文件夾,點擊右鍵,選擇“新建”→“Shapefile”,新建一個Shapefile文件。 在彈出的“新建Shapefile”對話框內“名稱”命名為“折線”,“要素類型”選…

阿里云通義實驗室自然語言處理方向負責人黃非:通義靈碼2.0,邁入 Agentic AI

通義靈碼是基于阿里巴巴通義大模型研發的AI 智能編碼助手&#xff0c;在通義靈碼 1.0 時代&#xff0c;我們針對代碼的生成、補全和問答&#xff0c;通過高效果、低時延&#xff0c;研發出了國內最受歡迎的編碼助手。 在通義靈碼 2.0 發布會上&#xff0c;阿里云通義實驗室自然…

Open3D 最小二乘擬合平面(直接求解法)【2025最新版】

目錄 一、算法原理二、代碼實現三、結果展示本文由CSDN點云俠原創,原文鏈接。如果你不是在點云俠的博客中看到該文章,那么此處便是不要臉的爬蟲與GPT。 博客長期更新,本文最近更新時間為:2025年1月18日。 一、算法原理 平面方程的一般表達式為:

超標量處理器設計2-cache

1. cache 介紹 影響Cache缺失的情況有3種&#xff1a; Compulsory: 第一次被訪問的指令或者數據肯定不會在cache中&#xff0c;需要通過預取來減少這種缺失Capcity: Cache容量越大&#xff0c;缺失就可以更少, 程序頻繁使用的三個數據來源于3個set&#xff0c; 但是&#xff…

linux 安裝PrometheusAlert配置釘釘告警

在 Linux 上安裝 PrometheusAlert 并配置釘釘告警的步驟如下: 1. 準備工作 釘釘機器人: 在釘釘群中創建一個機器人,獲取 Webhook URL。示例 Webhook URL:https://oapi.dingtalk.com/robot/send?access_token=your_dingtalk_token。PrometheusAlert 安裝包: 從 Prometheus…

當PHP遇上區塊鏈:一場奇妙的技術之旅

PHP 與區塊鏈的邂逅 在技術的廣袤宇宙中&#xff0c;區塊鏈技術如同一顆耀眼的新星&#xff0c;以其去中心化、不可篡改、透明等特性&#xff0c;掀起了一場席卷全球的變革浪潮。眾多開發者懷揣著對新技術的熱忱與探索精神&#xff0c;紛紛投身于區塊鏈開發的領域&#xff0c;試…

vscode的安裝與使用

下載 地址&#xff1a;https://code.visualstudio.com/ 安裝 修改安裝路徑&#xff08;不要有中文&#xff09; 點擊下一步&#xff0c;創建桌面快捷方式&#xff0c;等待安裝 安裝中文插件 可以根據自己的需要安裝python和Jupyter插件

32單片機綜合應用案例——物聯網(IoT)環境監測站(四)(內附詳細代碼講解!!!)

無論你身處何種困境&#xff0c;都要堅持下去&#xff0c;因為勇氣和毅力是成功的基石。不要害怕失敗&#xff0c;因為失敗并不代表終結&#xff0c;而是為了成長和進步。相信自己的能力&#xff0c;相信自己的潛力&#xff0c;相信自己可以克服一切困難。成功需要付出努力和堅…

淺談云計算19 | OpenStack管理模塊 (上)

OpenStack管理模塊&#xff08;上&#xff09; 一、操作界面管理架構二、認證管理2.1 定義與作用2.2 認證原理與流程2.2.1 認證機制原理2.2.2 用戶認證流程 三、鏡像管理3.1 定義與功能3.2 鏡像服務架構3.3 工作原理與流程3.3.1 鏡像存儲原理3.3.2 鏡像檢索流程 四、計算管理4.…