Eloquent是Laravel的原始ActiveRecord是實(shí)現(xiàn)的,建立在Laravel的Fluent Query Builder之上的,所以Eloquent類和Fluent類是一樣的,能實(shí)現(xiàn)復(fù)雜的SQL語(yǔ)句和非常直觀表達(dá)出的表與表之間的關(guān)系

ActiveRecord也屬于ORM層,由Rails最早提出,遵循標(biāo)準(zhǔn)的ORM模型:表映射到記錄,記錄映射到對(duì)象,字段映射到對(duì)象屬性。配合遵循的命名和配置慣例,能夠很大程度的快速實(shí)現(xiàn)模型的操作,而且簡(jiǎn)潔易懂。

ActiveRecord的主要思想是:

1. 每一個(gè)數(shù)據(jù)庫(kù)表對(duì)應(yīng)創(chuàng)建一個(gè)類,類的每一個(gè)對(duì)象實(shí)例對(duì)應(yīng)于數(shù)據(jù)庫(kù)中表的一行記錄;通常表的每個(gè)字段在類中都有相應(yīng)的Field;
2. ActiveRecord同時(shí)負(fù)責(zé)把自己持久化,在ActiveRecord中封裝了對(duì)數(shù)據(jù)庫(kù)的訪問(wèn),即CURD;;
3. ActiveRecord是一種領(lǐng)域模型(Domain Model),封裝了部分業(yè)務(wù)邏輯;

現(xiàn)在我們講講ActiveRecord在Laravel中的應(yīng)用

關(guān)于Eloquent的方法及其操作可以具體的可以看文檔,在這里我們主要講解表的關(guān)系

一對(duì)一的關(guān)系(one-to-one relationship)
關(guān)系數(shù)據(jù)庫(kù)中兩個(gè)表之間的一種關(guān)系,該關(guān)系中第一個(gè)表中的單個(gè)行只可以與第二個(gè)表中的一個(gè)行相關(guān),且第二個(gè)表中的一個(gè)行也只可以與第一個(gè)表中的一個(gè)行相關(guān)。
假如我們有一張user表和一張passport表是一對(duì)一的關(guān)系

首先讓我們來(lái)表達(dá)出這樣子的關(guān)系在我們的User類(用于操作user表)中

平面設(shè)計(jì)培訓(xùn),網(wǎng)頁(yè)設(shè)計(jì)培訓(xùn),美工培訓(xùn),游戲開(kāi)發(fā),動(dòng)畫(huà)培訓(xùn)

class User extends Eloquent  
{  
        public function passport()  
        {  
                return $this->has_one('Passport');//描述了在每一個(gè)用戶都有對(duì)應(yīng)的passport          }  
}

平面設(shè)計(jì)培訓(xùn),網(wǎng)頁(yè)設(shè)計(jì)培訓(xùn),美工培訓(xùn),游戲開(kāi)發(fā),動(dòng)畫(huà)培訓(xùn)

網(wǎng)友評(píng)論