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