国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > PHP > 正文

Yii2.0表關(guān)聯(lián)查詢實(shí)例分析

2020-03-22 20:15:10
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
本文實(shí)例講述了Yii2.0表關(guān)聯(lián)查詢的方法。分享給大家供大家參考,具體如下:你可以使用 ActiveRecord 來(lái)進(jìn)行關(guān)聯(lián)查詢(比如,從A表讀取數(shù)據(jù)時(shí)把關(guān)聯(lián)的B表數(shù)據(jù)也一起讀出來(lái)), 在Active Record中,獲取關(guān)聯(lián)數(shù)據(jù)可以像訪問(wèn)主表ActiveRecord對(duì)象的屬性(property)一樣簡(jiǎn)單。比如,通過(guò)合適的關(guān)系聲明,你可以使用 $customer- orders 來(lái)獲取一個(gè) Order 對(duì)象數(shù)組,代表該客戶下的訂單。要聲明一個(gè)關(guān)系(relation),定義一個(gè)getter方法,該方法返回一個(gè) yii/db/ActiveQuery 對(duì)象,擁有關(guān)聯(lián)上下文信息,這樣將只查詢符合條件的相關(guān)數(shù)據(jù)。比如:html' target='_blank'>class Customer extends /yii/db/ActiveRecord public function getOrders() // Customer has_many Order via Order.customer_id - id return $this- hasMany(Order::className(), ['customer_id' = 'id']);class Order extends /yii/db/ActiveRecord // Order has_one Customer via Customer.id - customer_id public function getCustomer() return $this- hasOne(Customer::className(), ['id' = 'customer_id']);上述代碼中的 yii/db/ActiveRecord::hasMany() 和 yii/db/ActiveRecord::hasOne() 是用來(lái)建模關(guān)系型數(shù)據(jù)庫(kù)中的 一對(duì)多 以及 一對(duì)一 關(guān)聯(lián)關(guān)系。比如,一個(gè)客戶customer有多個(gè)訂單orders,而一個(gè)訂單擁有或歸屬于一個(gè)用戶。兩個(gè)方法均接收兩個(gè)參數(shù)并返回一個(gè) yii/db/ActiveQuery 對(duì)象:$class: 關(guān)聯(lián)模型的類(lèi)名稱(chēng)。$link: 兩張表之間的列關(guān)聯(lián)。這得是一個(gè)數(shù)組。數(shù)組元素的鍵是 $class 所對(duì)應(yīng)表的列名稱(chēng),而數(shù)組元素的值是當(dāng)前聲明類(lèi)的列名稱(chēng)。依據(jù)表外鍵關(guān)聯(lián)來(lái)定義這些關(guān)系是一個(gè)好的編程實(shí)踐。完成上述聲明后,就可以通過(guò)定義相應(yīng)的getter方法來(lái)像訪問(wèn)對(duì)象屬性一樣獲取關(guān)聯(lián)數(shù)據(jù):// get the orders of a customer$customer = Customer::findOne(1);$orders = $customer- orders; // $orders is an array of Order objects上述代碼在幕后實(shí)際執(zhí)行了如下兩個(gè)SQL查詢,分別對(duì)應(yīng)于上述兩行代碼:SELECT * FROM customer WHERE id=1;SELECT * FROM order WHERE customer_id=1;提示:如果你再次訪問(wèn) $customer- orders ,并不會(huì)重復(fù)執(zhí)行上述第2行SQL查詢。這條查詢語(yǔ)句只在表達(dá)式第一次被訪問(wèn)時(shí)才被執(zhí)行。后續(xù)的訪問(wèn)將直接返回內(nèi)部緩沖數(shù)據(jù)。如果你想重新執(zhí)行查詢,只需要先調(diào)用一下unset來(lái)清除緩存:unset($customer- orders);.有時(shí)候,你可能想傳遞參數(shù)給關(guān)聯(lián)查詢來(lái)限定查詢條件。比如只想讀取超過(guò)指定數(shù)額的大額訂單,而不是所有訂單。為此,可以使用如下getter方法來(lái)聲明一個(gè) bigOrders 關(guān)系:class Customer extends /yii/db/ActiveRecord public function getBigOrders($threshold = 100) return $this- hasMany(Order::className(), ['customer_id' = 'id']) - where('subtotal :threshold', [':threshold' = $threshold]) - orderBy('id');記住 hasMany() 返回對(duì)象是一個(gè) yii/db/ActiveQuery ,因此ActiveQuery的方法都可以被用來(lái)定制這個(gè)關(guān)聯(lián)查詢。通過(guò)上述聲明,如果你訪問(wèn) $customer- bigOrders, 它將只返回?cái)?shù)額大于100的訂單。如果想指定一個(gè)不同的限定值,使用如下代碼:$orders = $customer- getBigOrders(200)- all();注意:關(guān)聯(lián)方法返回一個(gè) yii/db/ActiveQuery 實(shí)例。如果你以屬性(類(lèi)property)的方式來(lái)訪問(wèn)它,返回?cái)?shù)據(jù)是一個(gè) yii/db/ActiveRecord 實(shí)例、或者是ActiveRecord數(shù)組或?yàn)榭眨╪ull)。比如, $customer- getOrders() 返回一個(gè) ActiveQuery 實(shí)例,而$customer- orders 返回一個(gè) Order 對(duì)象數(shù)組(或者是一個(gè)空數(shù)組,如果查詢結(jié)果為空)。中間表關(guān)聯(lián)查詢有時(shí)候,一些數(shù)據(jù)表通過(guò)中間表(pivot table)關(guān)聯(lián)在一起。為了聲明這樣的關(guān)系,我們可以定制 yii/db/ActiveQuery 對(duì)象,通過(guò)調(diào)用它的 via() 或 viaTable() 方法。比如,如果訂單表 order 和商品表 item 通過(guò)連接表 order_item關(guān)聯(lián),我們可以在 Order 類(lèi)中聲明 items 關(guān)系如下:class Order extends /yii/db/ActiveRecord public function getItems() return $this- hasMany(Item::className(), ['id' = 'item_id']) - viaTable('order_item', ['order_id' = 'id']);via() 方法和 viaTable() 類(lèi)似,不過(guò)第一個(gè)參數(shù)是在當(dāng)前ActiveRecord類(lèi)中聲明的一個(gè)關(guān)系(relation)名,而不是中間表的名稱(chēng)。比如,上述 items 關(guān)系也可以用下面的方法進(jìn)行聲明:class Order extends /yii/db/ActiveRecord public function getOrderItems() return $this- hasMany(OrderItem::className(), ['order_id' = 'id']); public function getItems() return $this- hasMany(Item::className(), ['id' = 'item_id']) - via('orderItems');更多關(guān)于Yii相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《Yii框架入門(mén)及常用技巧總結(jié)》、《php優(yōu)秀開(kāi)發(fā)框架總結(jié)》、《smarty模板入門(mén)基礎(chǔ)教程》、《php面向?qū)ο?/u>程序設(shè)計(jì)入門(mén)教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門(mén)教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》希望本文所述對(duì)大家基于Yii框架的PHP程序設(shè)計(jì)有所幫助。PHP教程

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 云林县| 陇南市| 陆良县| 建昌县| 和田市| 会同县| 泽州县| 安庆市| 克拉玛依市| 沙洋县| 广饶县| 武清区| 洛川县| 平阴县| 托克逊县| 沁源县| 原阳县| 阿荣旗| 普陀区| 石台县| 永靖县| 阜新| 枣强县| 井研县| 佛山市| 鄂伦春自治旗| 昭觉县| 庆元县| 唐山市| 浦江县| 花莲市| 南开区| 铜山县| 石棉县| 伊吾县| 尉犁县| 婺源县| 陵水| 大姚县| 宁夏| 磴口县|