中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

Yii2.0表關聯查詢實例分析
來源:易賢網 閱讀:968 次 日期:2016-08-12 15:42:37
溫馨提示:易賢網小編為您整理了“Yii2.0表關聯查詢實例分析”,方便廣大網友查閱!

本文實例講述了Yii2.0表關聯查詢的方法。分享給大家供大家參考,具體如下:

你可以使用 ActiveRecord 來進行關聯查詢(比如,從A表讀取數據時把關聯的B表數據也一起讀出來), 在Active Record中,獲取關聯數據可以像訪問主表ActiveRecord對象的屬性(property)一樣簡單。

比如,通過合適的關系聲明,你可以使用 $customer->orders 來獲取一個 Order 對象數組,代表該客戶下的訂單。

要聲明一個關系(relation),定義一個getter方法,該方法返回一個 yii\db\ActiveQuery 對象,擁有關聯上下文信息,這樣將只查詢符合條件的相關數據。比如:

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框架的PHP程序設計有所幫助。

更多信息請查看網絡編程
易賢網手機網站地址:Yii2.0表關聯查詢實例分析
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
欧美午夜无遮挡| 国产精品你懂的| 麻豆精品在线视频| 国产精品久久久久久av福利软件 | 新67194成人永久网站| 久久久一区二区| 亚洲国产精品ⅴa在线观看| 亚洲人成艺术| 久久午夜激情| 国内成人精品2018免费看| 亚洲欧美日韩在线观看a三区| 欧美系列一区| 欧美日韩精品免费观看| 亚洲裸体俱乐部裸体舞表演av| 欧美经典一区二区| 亚洲女人天堂av| 国产欧美精品在线播放| 性做久久久久久久免费看| 噜噜噜躁狠狠躁狠狠精品视频| 国产综合第一页| 久久这里只有| 欧美一二三区精品| 亚洲人成在线观看网站高清| 欧美日韩国产成人高清视频| 最新亚洲激情| 国产精品免费在线| 麻豆成人在线| 亚洲在线观看视频| 最新国产拍偷乱拍精品 | 久久精品一本| 一区二区三区.www| 欧美日韩一区二区在线播放| 欧美精品一区二区三| 欧美三级欧美一级| 玖玖玖免费嫩草在线影院一区| 亚洲级视频在线观看免费1级| 国产精品一区一区| 欧美日韩一区二区三区在线视频| 免费成人美女女| 久久亚洲一区二区| 欧美激情中文字幕一区二区 | 欧美精品系列| 欧美日韩亚洲视频一区| 欧美日韩国产经典色站一区二区三区| 久久裸体艺术| 欧美日韩国产在线播放网站| 欧美视频在线一区二区三区| 国产精品美女久久久免费| 国产亚洲精品久久飘花| 亚洲国产你懂的| 亚洲欧美美女| 美女视频一区免费观看| 欧美mv日韩mv国产网站app| 欧美三区不卡| 亚洲国产99精品国自产| 亚洲欧美不卡| 欧美激情第一页xxx| 国产精品久久久久一区二区三区| 国产真实乱子伦精品视频| 91久久线看在观草草青青| 亚洲一区三区电影在线观看| 蜜臀久久99精品久久久画质超高清 | 欧美亚洲免费在线| 国产欧美日韩亚洲精品| 亚洲人体1000| 国产欧亚日韩视频| 欧美国产日韩二区| 欧美在现视频| 这里只有精品视频| 亚洲全黄一级网站| 国产日韩一区欧美| 欧美日韩国产成人在线91| 亚洲福利视频二区| 亚洲视频欧洲视频| 国产精品视频网站| 欧美在线欧美在线| 亚洲国产精品小视频| 欧美日韩国产综合在线| 亚洲九九九在线观看| 欧美四级电影网站| 亚洲性感美女99在线| 国产精品毛片| 午夜精品一区二区三区在线播放| 国产欧美综合一区二区三区| 亚洲资源在线观看| 国产视频观看一区| 欧美xxx在线观看| 亚洲一区中文| 海角社区69精品视频| 欧美大香线蕉线伊人久久国产精品| 欧美精品在线免费| 久久精品国产亚洲aⅴ| 亚洲最新在线视频| 亚洲国产精品va在线看黑人动漫| 亚洲成人在线网| 欧美午夜无遮挡| 狠狠爱综合网| 亚洲三级影院| 久久久91精品国产| 狠狠色丁香婷婷综合| 亚洲二区视频在线| 99精品久久久| 国产精品成人va在线观看| 欧美日韩岛国| 在线观看三级视频欧美| 老色鬼久久亚洲一区二区 | 国产一区二区精品在线观看| 国产欧美综合在线| 亚洲无线视频| 国产精品区二区三区日本| 久久久久国内| 欧美亚洲视频| 亚洲欧美激情四射在线日 | 欧美日韩久久| 蜜臀a∨国产成人精品| 久久久精品2019中文字幕神马| 亚洲欧美春色| 久久国产精品久久久久久| 性视频1819p久久| 欧美在线综合视频| 久久午夜电影| 欧美极品在线视频| 欧美视频在线观看一区二区| 国产精品国产成人国产三级| 国产欧美另类| 亚洲人成网站777色婷婷| 一区二区三区产品免费精品久久75| 国产精品99久久久久久久久| 午夜日韩激情| 欧美精品在线免费| 国产精品永久免费在线| 1769国内精品视频在线播放| 夜夜嗨网站十八久久| 久久精品国产91精品亚洲| 欧美黄色片免费观看| 国产日韩欧美麻豆| 99xxxx成人网| 欧美成人dvd在线视频| 国产麻豆精品视频| av72成人在线| 欧美理论电影网| 激情久久久久久久久久久久久久久久| 一区二区三区精品视频在线观看| 久久精品国产精品| 国产一区二区久久久| 亚洲欧美日韩视频二区| 欧美日韩一区三区四区| 在线观看亚洲视频啊啊啊啊| 午夜精品久久久99热福利| 欧美色网在线| 亚洲综合日韩在线| 国产伦精品一区| 久久精品麻豆| 在线国产欧美| 欧美国产日本高清在线| 亚洲人屁股眼子交8| 欧美刺激性大交免费视频 | 欧美日韩在线观看视频| 亚洲大黄网站| 欧美日韩一区在线观看| 99国内精品久久久久久久软件| 欧美日韩精品二区| 亚洲永久网站| 国产一区二区三区四区老人| 久久最新视频| 一区二区日韩伦理片| 精品av久久久久电影| 欧美日韩在线播放一区| 亚洲欧美另类综合偷拍| 亚洲福利在线观看| 国产精品sss| 欧美电影美腿模特1979在线看| 国产精品99久久99久久久二8 | 激情欧美一区二区| 欧美激情第二页| 老牛影视一区二区三区| 在线亚洲一区二区| 亚洲国产精品t66y| 国内精品久久久久影院 日本资源 国内精品久久久久伊人av | 中文有码久久| 日韩午夜在线播放| 91久久精品日日躁夜夜躁欧美 | 欧美日韩高清区| 欧美成人高清视频| 久久电影一区| 午夜欧美大片免费观看| 亚洲综合另类| 欧美一区亚洲| 久久久久久久综合日本| 午夜日韩电影| 欧美在线观看视频| 久久人人爽人人爽| 久久一区欧美| 狂野欧美激情性xxxx欧美| 久久久久久久久久久一区| 久久国产精品久久国产精品| 久久国产精品高清| 久久综合亚州| 欧美男人的天堂| 久久综合色8888|