亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > PHP > 正文

Yii2.0表關聯查詢實例分析

2020-03-22 20:15:10
字體:
來源:轉載
供稿:網友
本文實例講述了Yii2.0表關聯查詢的方法。分享給大家供大家參考,具體如下:你可以使用 ActiveRecord 來進行關聯查詢(比如,從A表讀取數據時把關聯的B表數據也一起讀出來), 在Active Record中,獲取關聯數據可以像訪問主表ActiveRecord對象的屬性(property)一樣簡單。比如,通過合適的關系聲明,你可以使用 $customer- orders 來獲取一個 Order 對象數組,代表該客戶下的訂單。要聲明一個關系(relation),定義一個getter方法,該方法返回一個 yii/db/ActiveQuery 對象,擁有關聯上下文信息,這樣將只查詢符合條件的相關數據。比如: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() 是用來建模關系型數據庫中的 一對多 以及 一對一 關聯關系。比如,一個客戶customer有多個訂單orders,而一個訂單擁有或歸屬于一個用戶。兩個方法均接收兩個參數并返回一個 yii/db/ActiveQuery 對象:$class: 關聯模型的類名稱。$link: 兩張表之間的列關聯。這得是一個數組。數組元素的鍵是 $class 所對應表的列名稱,而數組元素的值是當前聲明類的列名稱。依據表外鍵關聯來定義這些關系是一個好的編程實踐。完成上述聲明后,就可以通過定義相應的getter方法來像訪問對象屬性一樣獲取關聯數據:// get the orders of a customer$customer = Customer::findOne(1);$orders = $customer- orders; // $orders is an array of Order objects上述代碼在幕后實際執行了如下兩個SQL查詢,分別對應于上述兩行代碼:SELECT * FROM customer WHERE id=1;SELECT * FROM order WHERE customer_id=1;提示:如果你再次訪問 $customer- orders ,并不會重復執行上述第2行SQL查詢。這條查詢語句只在表達式第一次被訪問時才被執行。后續的訪問將直接返回內部緩沖數據。如果你想重新執行查詢,只需要先調用一下unset來清除緩存:unset($customer- orders);.有時候,你可能想傳遞參數給關聯查詢來限定查詢條件。比如只想讀取超過指定數額的大額訂單,而不是所有訂單。為此,可以使用如下getter方法來聲明一個 bigOrders 關系: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() 返回對象是一個 yii/db/ActiveQuery ,因此ActiveQuery的方法都可以被用來定制這個關聯查詢。通過上述聲明,如果你訪問 $customer- bigOrders, 它將只返回數額大于100的訂單。如果想指定一個不同的限定值,使用如下代碼:$orders = $customer- getBigOrders(200)- all();注意:關聯方法返回一個 yii/db/ActiveQuery 實例。如果你以屬性(類property)的方式來訪問它,返回數據是一個 yii/db/ActiveRecord 實例、或者是ActiveRecord數組或為空(null)。比如, $customer- getOrders() 返回一個 ActiveQuery 實例,而$customer- orders 返回一個 Order 對象數組(或者是一個空數組,如果查詢結果為空)。中間表關聯查詢有時候,一些數據表通過中間表(pivot table)關聯在一起。為了聲明這樣的關系,我們可以定制 yii/db/ActiveQuery 對象,通過調用它的 via() 或 viaTable() 方法。比如,如果訂單表 order 和商品表 item 通過連接表 order_item關聯,我們可以在 Order 類中聲明 items 關系如下: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() 類似,不過第一個參數是在當前ActiveRecord類中聲明的一個關系(relation)名,而不是中間表的名稱。比如,上述 items 關系也可以用下面的方法進行聲明: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');更多關于Yii相關內容感興趣的讀者可查看本站專題:《Yii框架入門及常用技巧總結》、《php優秀開發框架總結》、《smarty模板入門基礎教程》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》希望本文所述對大家基于Yii框架的PHP程序設計有所幫助。PHP教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久人人爽人人爽人人片亚洲| 久久综合久久美利坚合众国| 欧美孕妇毛茸茸xxxx| 亚洲欧洲国产精品| 亚洲人成欧美中文字幕| 欧美视频国产精品| 欧美最猛性xxxxx亚洲精品| 日韩精品高清在线| 成人激情综合网| 亚洲美女精品成人在线视频| 国产99视频在线观看| 美女999久久久精品视频| 成人黄色短视频在线观看| 亚洲国产欧美一区二区三区同亚洲| 国产日韩专区在线| 国产精品久久久久久久7电影| 久久视频免费在线播放| 亚洲自拍偷拍色片视频| 午夜精品一区二区三区视频免费看| 日日狠狠久久偷偷四色综合免费| 国产成人精彩在线视频九色| 亚洲全黄一级网站| 午夜免费在线观看精品视频| 亚洲欧美日韩一区二区三区在线| 亚洲成人黄色在线观看| 国产精品99导航| 欧美大尺度在线观看| 欧美极品少妇xxxxⅹ裸体艺术| 亚洲欧美日韩精品| 亚洲成av人影院在线观看| 欧美有码在线观看视频| 欧美电影在线观看网站| 亚洲人成电影网站色…| 中文字幕精品—区二区| 国产日韩欧美91| 国产精品久久久久久久久| 欧美激情视频一区二区| 欧美国产日本在线| 亚洲国产一区二区三区四区| 欧美激情一区二区三区在线视频观看| 国产精品wwwwww| 日韩经典第一页| 欧美丰满少妇xxxxx| 国产一区二区日韩| 亚洲香蕉伊综合在人在线视看| 国产丝袜精品视频| 国产精品成人一区二区| 久久成人精品电影| 精品一区二区三区三区| 精品在线小视频| 欧美日韩免费网站| 色综合久久久久久中文网| 国产一区二区三区毛片| 欧洲亚洲免费视频| 91在线观看免费观看| 亚洲天堂影视av| 亚洲国产成人在线播放| 日韩经典中文字幕在线观看| 一区二区福利视频| 亚洲国产另类 国产精品国产免费| 高清亚洲成在人网站天堂| 欧美日韩第一页| 日韩精品极品视频| 日韩av在线精品| 九九九热精品免费视频观看网站| 欧美第一黄网免费网站| 欧美日韩xxx| 亚洲欧美日本另类| 久久久久久久色| 国产在线日韩在线| 亚洲一级片在线看| 亚洲国产精品嫩草影院久久| 色偷偷88888欧美精品久久久| 久久久精品视频成人| 国产va免费精品高清在线观看| 色综合伊人色综合网| 亚洲色无码播放| 青青久久av北条麻妃黑人| 青青久久aⅴ北条麻妃| 日韩在线观看电影| 欧美一级高清免费播放| 国产精品一二三视频| 久久久精品999| 欧美大片在线免费观看| 26uuu日韩精品一区二区| 国产欧美最新羞羞视频在线观看| 欧美午夜片欧美片在线观看| 久久精品小视频| 日韩精品欧美国产精品忘忧草| 黄网站色欧美视频| 欧美性视频精品| 日韩欧美精品免费在线| 欧美日韩一区二区免费视频| 国产一区二区三区免费视频| 国产精品女主播| 日韩电影中文 亚洲精品乱码| 日韩有码在线视频| 一区二区三区视频在线| 亚洲美女久久久| 欧美精品www在线观看| 亚洲无亚洲人成网站77777| 中文字幕在线看视频国产欧美| 亚洲香蕉在线观看| 欧美www在线| 午夜精品蜜臀一区二区三区免费| 欧美国产日韩二区| 日韩精品免费在线视频| 亚洲第一av网| 伊是香蕉大人久久| 国产成人一区二区三区电影| 国产69精品久久久久久| 日韩中文字幕在线看| 久久精品色欧美aⅴ一区二区| 亚洲美女黄色片| 91国产一区在线| 97精品在线视频| 91美女福利视频高清| 精品人伦一区二区三区蜜桃网站| 亚洲在线免费视频| 久久久久在线观看| 亚洲自拍另类欧美丝袜| 亚州欧美日韩中文视频| 久久久久在线观看| 国产精品视频最多的网站| 亚洲天天在线日亚洲洲精| 国产精品18久久久久久首页狼| 国产精品女主播视频| 欧美日韩性视频| 2019亚洲日韩新视频| 欧美成人第一页| 国产成+人+综合+亚洲欧洲| 夜夜嗨av色一区二区不卡| 亚洲视频在线观看网站| 亚洲精品日韩激情在线电影| 亚洲精品第一国产综合精品| 国产欧美日韩精品在线观看| 美女少妇精品视频| 国产欧美一区二区三区四区| 亚洲色图综合网| 日韩电视剧免费观看网站| 国产区亚洲区欧美区| 少妇av一区二区三区| 日韩精品在线观看一区二区| 亚洲精品乱码久久久久久金桔影视| 91av在线播放| 国产精品美女视频网站| 久久av资源网站| 国产精品一区二区三区免费视频| 久久69精品久久久久久久电影好| 国产有码一区二区| 国产69久久精品成人看| 国产精品精品国产| 色偷偷偷亚洲综合网另类| 色婷婷av一区二区三区久久| 午夜精品视频网站| 57pao精品| 久久精品青青大伊人av| 国产69精品久久久久9| 亚洲一区二区自拍| 91精品久久久久久久久久入口| 日韩中文字幕国产| 欧美重口另类videos人妖| 亚洲成人av在线| 九九久久国产精品|