Eloquent是Laravel的原始ActiveRecord是實現(xiàn)的,建立在Laravel的Fluent Query Builder之上的,所以Eloquent類和Fluent類是一樣的,能實現(xiàn)復(fù)雜的SQL語句和非常直觀表達(dá)出的表與表之間的關(guān)系
ActiveRecord也屬于ORM層,由Rails最早提出,遵循標(biāo)準(zhǔn)的ORM模型:表映射到記錄,記錄映射到對象,字段映射到對象屬性。配合遵循的命名和配置慣例,能夠很大程度的快速實現(xiàn)模型的操作,而且簡潔易懂。
ActiveRecord的主要思想是:
1. 每一個數(shù)據(jù)庫表對應(yīng)創(chuàng)建一個類,類的每一個對象實例對應(yīng)于數(shù)據(jù)庫中表的一行記錄;通常表的每個字段在類中都有相應(yīng)的Field;
2. ActiveRecord同時負(fù)責(zé)把自己持久化,在ActiveRecord中封裝了對數(shù)據(jù)庫的訪問,即CURD;;
3. ActiveRecord是一種領(lǐng)域模型(Domain Model),封裝了部分業(yè)務(wù)邏輯;
現(xiàn)在我們講講ActiveRecord在Laravel中的應(yīng)用
關(guān)于Eloquent的方法及其操作可以具體的可以看文檔,在這里我們主要講解表的關(guān)系
一對一的關(guān)系(one-to-one relationship)
關(guān)系數(shù)據(jù)庫中兩個表之間的一種關(guān)系,該關(guān)系中第一個表中的單個行只可以與第二個表中的一個行相關(guān),且第二個表中的一個行也只可以與第一個表中的一個行相關(guān)。
假如我們有一張user表和一張passport表是一對一的關(guān)系
首先讓我們來表達(dá)出這樣子的關(guān)系在我們的User類(用于操作user表)中
class User extends Eloquent { public function passport() { return $this->has_one('Passport');//描述了在每一個用戶都有對應(yīng)的passport } }
延伸閱讀
- ssh框架 2016-09-30
- 阿里移動安全 [無線安全]玩轉(zhuǎn)無線電——不安全的藍(lán)牙鎖 2017-07-26
- 消息隊列NetMQ 原理分析4-Socket、Session、Option和Pipe 2024-03-26
- Selective Search for Object Recognition 論文筆記【圖片目標(biāo)分割】 2017-07-26
- 詞向量-LRWE模型-更好地識別反義詞同義詞 2017-07-26
- 從棧不平衡問題 理解 calling convention 2017-07-26
- php imagemagick 處理 圖片剪切、壓縮、合并、插入文本、背景色透明 2017-07-26
- Swift實現(xiàn)JSON轉(zhuǎn)Model - HandyJSON使用講解 2017-07-26
- 阿里移動安全 Android端惡意鎖屏勒索應(yīng)用分析 2017-07-26
- 集合結(jié)合數(shù)據(jù)結(jié)構(gòu)來看看(二) 2017-07-26