搜尋
首頁php框架Laravel詳細解析Laravel Model模型關聯

本篇文章為大家帶來了關於laravel的相關知識,其中主要介紹了關於Model模型關聯的相關問題,包括了一對一、一對多、多對多等內容,下面一起來看一下,希望對大家有幫助。

詳細解析Laravel Model模型關聯

【相關推薦:laravel影片教學

定義關聯關係

資料庫表通常會相互關聯。
例如,一篇部落格文章可能有許多評論,或一個訂單對應一個下單用戶。 Eloquent 讓這些關聯的管理和使用變得簡單,並支援多種類型的關聯:常見的為前三種,在此我們也只講解前三種關聯

    ##一對一
  • 一對多
  • 多對多
  • 遠端一對多
  • 遠端一對一
  • 一對一(多態關聯)
  • 一對一(多態關聯)
  • 多對多
#建立模型關聯

一對一

範例: 兩個資料表:
guest 使用者表和guestinfo使用者資訊 其中
guest 表中的主鍵id欄位對應guestinfo中的外鍵user_id欄位 首先建立兩個model檔案:

php artisan make:model Guest##php artisan make:model Guestinfo
Guest model檔案:

class Guest extends Model{
    use HasFactory;
    // 设置Guest模型对应的数据表
    protected $table = 'guest';
    // 关闭create_time和update_time字段自动管理
    public $timestamps = false;
    // 设置与guestinfo的关联方法,方法名建议使用被关联表的名字
    public function guestinfo(){
    // hasOne(被关联的名命空间,关联外键,关联的主键)
        return $this->hasOne('App\Models\Guestinfo','user_id','id');
    }}

Guestinfo model檔案:
class Guestinfo extends Model{
    use HasFactory;
    // 设置Guest模型对应的数据表
    protected $table = 'guestinfo';
    // 关闭create_time和update_time字段自动管理
    public $timestamps = false;
    // 设置与guestinfo的关联方法,方法名建议使用被关联表的名字
    public function guest(){
    // hasOne(被关联的名命空间,关联外键,关联的主键)
        return $this->belongsTo('App\Models\Guest','user_id','id');
    }}

建立一個控制器將兩個model檔案連接起來:

php artisan make:controller Controllers
內容:

class Controllers extends Controller{
    //
    public function getOne(){
    // 通过关联方法获取guest表中username = admin记录在guestinfo对应的记录
    // ->guestinfo 是Guest模型文件里面定义的guestinfo方法
        $guestInfo = Guest::firstWhere('username','admin')->guestinfo;
	// 通过关联方法获取guestinfo中id=3 记录在guest表中的对应记录
        $data = Guestinfo::find(3)->guest;
        
        dump($guestInfo);
        // 将模型转换成数组
        dump($data->toArray());
    }}

建立控制器的路由:

Route::get('relative/getOne',[Controllers::class,'getOne']);
存取路由: 結果為:


詳細解析Laravel Model模型關聯

一對多

範例:

兩個資料表:guest
使用者表和article文章表 其中guest
表中的主鍵id欄位對應著guestinfo中的外鍵user_id欄位 創建article
model檔:php artisan make:model Article
<pre class="brush:php;toolbar:false">class Article extends Model{     use HasFactory;     // 设置Guest模型对应的数据表     protected $table = 'article'; // 关闭create_time和update_time字段自动管理         public $timestamps = false;     public function guest(){     // 设置与guest的关联方法,与一对一的从表设置一样         return $this-&gt;belongsTo('App\Models\April\Guest','user_id','id');     }}</pre>

Guest

model檔案中加入一個article 方法<pre class="brush:php;toolbar:false">class Guest extends Model{     use HasFactory;     // 设置Guest模型对应的数据表     protected $table = 'guest';     // 关闭create_time和update_time字段自动管理     public $timestamps = false;     // 设置与guestinfo的关联方法,方法名建议使用被关联表的名字     public function guestinfo(){     // hasOne(被关联的名命空间,关联外键,关联的主键)         return $this-&gt;hasOne('App\Models\Guestinfo','user_id','id');     }     // 设置与article的关联:hasmany 有很多      public function article(){         return $this-&gt;hasMany('App\Models\April\Article','user_id','id');     }}</pre>

Controllers

控制器檔案中測試一下: 實例1:查詢某一個使用者發表的所有文章:

 		// 查询某个用户发表的所有文章
        $article = Guest::find(1)->article;
        // 返回为数据集,需要遍历
        foreach ($article as $v){
            dump($v->toArray());
        }

詳細解析Laravel Model模型關聯#實例2:查詢某個使用者最新發表的文章

		// 查询某个用户最新发表的一篇文章
        // article()生成一个构造器,可以进行筛选
        $article = Guest::find(1)->article()->orderby('created_at','desc')->first();
        dump($article->toArray());

# 實例3:透過關聯查詢某篇文章的發表人的姓名詳細解析Laravel Model模型關聯

		//  通过article和guest关联,再通过guest关联的guestinfo获取姓名
        $name = Article::find(2)->guest->guestinfo;
        dump($name->name);

實例4:透過關聯查詢某篇文章的評論資訊 建立Comment評論模型:


#php artisan make:model Comment
Comment 模型程式碼:

class Comment extends Model{
    use HasFactory;
    // 设置Comment模型对应的数据表
    protected $table = 'comment';
    // 关闭create_time和update_time字段自动管理
    public $timestamps = false;
    // 设置与article的关联方法,方法名建议使用被关联表的名字
    public function article(){
        return $this->belongsTo('App\Models\April\Article','article_id','id');
    }}

在Article模型中新增方法comment:
public function comment(){
        return $this->hasMany('App\Models\April\Comment','article_id','id');
    }

controller控制器程式碼:

$info = Article::find(2)->comment;
        foreach ($info as $v){
            dump($v->toArray());
        }

詳細解析Laravel Model模型關聯【相關推薦:

laravel影片教學

以上是詳細解析Laravel Model模型關聯的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:CSDN。如有侵權,請聯絡admin@php.cn刪除
Laravel(PHP)與Python:不同的用例和應用Laravel(PHP)與Python:不同的用例和應用Apr 18, 2025 am 12:16 AM

選擇Laravel或Python取決於項目需求:1)若需快速開發Web應用並使用ORM和認證系統,選Laravel;2)若涉及數據分析、機器學習或科學計算,選Python。

Laravel和Python:找到合適的工具Laravel和Python:找到合適的工具Apr 18, 2025 am 12:14 AM

Laravel适合快速构建Web应用,Python适用于需要灵活性和多功能性的项目。1)Laravel提供丰富功能如ORM和路由,适合PHP生态系统。2)Python以简洁语法和强大库生态系统著称,适用于Web开发和数据科学等领域。

Laravel和PHP:創建動態網站Laravel和PHP:創建動態網站Apr 18, 2025 am 12:12 AM

使用Laravel和PHP可以高效且有趣地創建動態網站。 1)Laravel遵循MVC架構,Blade模板引擎簡化HTML編寫。 2)路由系統和請求處理機制使URL定義和用戶輸入處理變得簡單。 3)EloquentORM簡化數據庫操作。 4)通過博客系統示例展示了數據庫遷移、CRUD操作和Blade模板的使用。 5)Laravel提供了強大的用戶認證和授權功能。 6)調試技巧包括使用日誌系統和Artisan工具。 7)性能優化建議包括惰性加載和緩存。

拉維爾(Laravel)和完整的堆棧:前後一起拉維爾(Laravel)和完整的堆棧:前後一起Apr 18, 2025 am 12:07 AM

Laravel通過Blade模板引擎、EloquentORM、Artisan工具和LaravelMix實現全棧開發:1.Blade簡化前端開發;2.Eloquent簡化數據庫操作;3.Artisan提高開發效率;4.LaravelMix管理前端資源。

Laravel:現代網絡開發的框架Laravel:現代網絡開發的框架Apr 18, 2025 am 12:05 AM

Laravel是一個基於PHP的現代化框架,遵循MVC架構模式,提供了豐富的工具和功能,簡化了Web開發過程。 1)它包含EloquentORM用於數據庫交互,2)Artisan命令行接口用於快速生成代碼,3)Blade模板引擎用於高效的視圖開發,4)強大的路由系統用於定義URL結構,5)認證系統用於用戶管理,6)事件監聽和廣播用於實時功能,7)緩存和隊列系統用於性能優化,使得構建和維護現代Web應用變得更加容易和高效。

Laravel(PHP)與Python:權衡優點和缺點Laravel(PHP)與Python:權衡優點和缺點Apr 17, 2025 am 12:18 AM

Laravel适合快速构建Web应用,而Python适用于更广泛的应用场景。1.Laravel提供EloquentORM、Blade模板引擎和Artisan工具,简化Web开发。2.Python以动态类型、丰富的标准库和第三方生态系统著称,适用于Web开发、数据科学等领域。

Laravel vs. Python:比較框架和圖書館Laravel vs. Python:比較框架和圖書館Apr 17, 2025 am 12:16 AM

Laravel和Python各有優勢:Laravel適合快速構建功能豐富的Web應用,Python在數據科學和通用編程領域表現出色。 1.Laravel提供EloquentORM和Blade模板引擎,適合構建現代Web應用。 2.Python擁有豐富的標準庫和第三方庫,Django和Flask框架滿足不同開發需求。

Laravel的目的:構建強大而優雅的Web應用程序Laravel的目的:構建強大而優雅的Web應用程序Apr 17, 2025 am 12:13 AM

Laravel值得選擇,因為它能使代碼結構清晰,開發過程更具藝術性。 1)Laravel基於PHP,遵循MVC架構,簡化Web開發。 2)其核心功能如EloquentORM、Artisan工具和Blade模板增強了開發的優雅與健壯性。 3)通過路由、控制器、模型和視圖,開發者能高效構建應用。 4)隊列和事件監聽等高級功能進一步提升應用性能。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前By尊渡假赌尊渡假赌尊渡假赌
威爾R.E.P.O.有交叉遊戲嗎?
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中