国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 編程 > 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教程

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
日本中文字幕在线播放| 天天操天天操天天色天天要| 国产一级性片| 中文字幕在线永久在线视频| 国产日韩精品在线看| 国产黄色大片在线观看| 国产福利免费在线观看| 中文字幕av高清| 日本福利在线| 国产精品久久久高清免费| 国产爆初菊在线观看免费视频网站 | av福利在线播放| 99高清免费国产自产拍| 青青青青在线| 成人无遮挡免费网站视频在线观看| 资源视频在线播放免费| 精品999视频| 国产资源在线看| 国产盗摄精品一区二区酒店| www.狠狠艹| 国产高清在线| 国产免费福利网站| 在线免费国产| 五月婷婷导航| 精品久久九九| 国产美女免费观看| 免费的黄网站在线观看| 在线视频1区2区| 中文字幕在线观看av| 俺来俺也去www色在线观看| 2021天堂中文幕一二区在线观| 免费在线看v| 一本大道五月香蕉| 国产极品一区二区三区 | 国产激情自拍视频| 国产美女视频网站| 在线观看视频污| 国产精品一区在线看| 尤物在线视频观看| 国产三级在线看| 国产精品视频福利一区二区| 国产免费黄网站| 丁香花在线电影小说观看 | www.夜夜操| 2019中文字幕在线电影免费| 中文字幕有码在线视频| 国产精品自产拍在线网站| 天堂网中文在线| 亚洲精品天堂在线观看| 亚洲精品国自产拍在线观看| 国产亚洲精品一区二区在线观看| 午夜免费视频在线国产| 国产欧美黑人| 97视频在线| 在线天堂av| 羞羞视频在线观看免费| 亚洲国产日韩在线人成电影| 在线看a视频| 青草青在线视频| 欧美性猛交xxxx免费看蜜桃| 黄网在线免费| 国产无遮挡在线视频免费观看| 中文字幕在线免费看| 国产精品冒白浆免费视频 | 国产美女免费观看| 国产精品自拍在线观看| 中文字幕国产视频| 国产香蕉视频在线观看| 一区二区精品区| 成年人在线观看| 国产成人精品实拍在线| 欧美黑人乱大交ⅹxxxxx| 午夜视频免费在线观看| 国产色在线观看| 欧美性xxxx交| 国产成人天天5g影院| 日本在线天堂| 国产黄色免费网| 国精一区二区三区| 亚洲国产精华液| 国产人成精品| 国产女王在线**视频 | 中文在线官网天堂| 国产毛片视频| 在线观看中文字幕一区| 99视频在线观看地址| 亚洲精品男人| 国产h在线观看| 日本中文字幕在线视频| 日本不卡1区2区3区| 综合激情丁香| 久久久久久77777| 在线视频二区| 在线中文字幕观看| 国产精品bbw一区二区三区| 丁香花视频在线观看| 蜜桃视频中文字幕| gogogogo高清视频在线| 精品女厕厕露p撒尿| 国产香蕉尹人视频在线| 国产在线播放av| 免费a级在线播放| а√最新版地址在线天堂| 精品国内自产拍在线视频| 国产精品久久精品牛牛影视| 国产麻豆视频免费观看| 久蕉依人在线视频| 超碰免费在线观看| 高清欧美精品xxxxx在线看| 青青艹在线视频| 人成在线免费视频| 欧美性猛交p30| 久久99精品久久久久久野外| 高清欧美精品xxxxx在线看| 成网站在线观看人免费| 天堂资源在线中文| 国产精品国精产品一二| 2018中文字幕在线观看| 精品国产免费第一区二区| 在线观看av中文| 在线免费看黄网站| av免费网站在线观看| 午夜亚洲成人| 美女av在线播放| 国产午夜视频在线观看| 精品国产高清a毛片无毒不卡 | 中文视频在线| 欧美黑人乱大交| 国产偷窥老熟盗摄视频| 精品国语对白精品自拍视| 精品网站www| 九九热视频免费在线观看| 国产日产精品久久久久久婷婷| 伊人久久青青草| 国产麻豆精品入口在线观看 | 国产区在线看| 快射av在线播放一区| 国产福利免费在线观看| 免费99热在线观看| 国产91足控脚交在线观看| 四虎在线免费视频| 午夜av电影| 热99在线观看| 国产精品69xx| 九九热在线观看| 亚洲国产成人综合| 国产偷倩在线播放| 免费a级毛片在线观看| 国产超级va在线视频| 国产麻豆视频网站| 久热av在线| av在线不卡播放| 亚洲电影先锋| 亚洲伊人网在线观看| 91看片在线观看| 国产成人福利| 国产91久久久久蜜臀青青天草二| 国产精品自产拍在线观看2019| www.国产精| av网址在线免费观看| 精品一区二区三区在线观看l| 国产性一级片| 国产日本在线视频| 国产精品久久久久久久久鸭| 国产精品人人爱一区二区白浆| 国产美女一区视频| 最近最好的中文字幕2019免费 | 开心激情五月婷婷| 免费99热在线观看| av手机免费在线观看| 精品欧美不卡一区二区在线观看 | 中文字幕日本在线观看| 中文字幕在线视频观看| 天天操天天艹| 国产精品区一区二| 91www在线观看| av在线free| 欧美黑人乱大交| 国内自拍视频在线观看| 91超碰在线免费| 国产娇喘精品一区二区三区图片| 国产二区视频在线观看| 国产porny蝌蚪视频| 国产小视频免费在线观看| 国产香蕉在线| 亚洲欧美综合乱码精品成人网| 青青青青在线| 国产在线传媒| 国产三区视频在线观看| av大片在线| 久草亚洲一区| 最近中文字幕mv免费高清在线| 国产91足控脚交在线观看| 亚洲成人国产综合| 国产一二区视频| 在线观看免费视频一区二区三区| 狠狠操天天操夜夜操| 五月综合网站| 樱花草在线观看www| 尤物视频免费在线观看|