最近專案中遇到了YII2多表關聯的相關問題,並沒有找到合適的資料,於是自己整理了下,方便自己在以後需要的時候或者有需要的朋友們參考學習。本文主要跟大家介紹了關於YII2中多表關聯的使用方法,需要的朋友下面來一起看看吧。希望對大家有幫助。
前言
本文對 YII2.0 的多表關聯查詢做一個簡單的介紹。文中透過實例程式碼介紹的非常詳細,下面話不多說,來一起看看詳細的介紹:
#首先先來說明一下表格結構
#表格結構
現在有訂單表、使用者表、商品清單表、商品庫存表
#在YII中,如果想直接關聯其他表進行查詢的話,需要先在模型裡定義它們的關聯
Order
class Order extends \yii\db\ActiveRecord.{ // 关联函数以get+要关联的数据表名来命名 // 这是获取下订单的客户 public function getUser(){ // 第一个参数为要关联的子表模型类名, // 第二个参数指定 通过子表的user_id,关联主表的usesr_id字段 // 这里写清楚点大概意思就是User.user_id => Order.user_id return $this->hasMany(User::className(), ['user_id' => 'user_id']); } }
1、hasMany、hasOne使用
#Yii2中的表之間的關聯有2種,它們用來指定兩個模型之間的關聯。
●一對一: hasMany ●一對一:hasOne
關聯的使用
//获取订单信息 $order = Order::findOne(1); //根据订单信息获取到用户信息 $user = $order->user;
//返回订单信息(包括用户信息) $order = Order::find(1)->with('user'); //或者 $order = Order::find(1)->getUser();
SELECT * FROM order WHERE id=1; SELECT * FROM user WHERE user.user_id=order.user_id;
從上面可以看出存取一個關聯的時候有兩種方法
●如果以函數的方式調用,會傳回一個ActiveQuery 物件( $customer->getOrders()->all()) ●如果以屬性的方式調用,則會直接返回模型的結果($customer->orders)關聯結果快取
如果這時order表發生了改變,我們希望再次查詢的話$user = $order->user;
//先释放缓存 unset($order->user); $order->user;
跨表查詢
User
public function getOrder() { return $this->hasMany(Order::className(), ['user_id' => 'user_id']); } public function getOrderGoods() { return $this->hasMany(OrderGoods::className(), ['order_id' => 'order_id'])-> via('order'); }
這裡注意:getOrderGoods中的第二個order_id是指getOrder關聯的Order中的order_id,第一個order_id是指OrderGoods中的order_id。
但是!我們還有最簡單的方法,就是使用SQL語句囉!$map = 'select user.name, order.id, order_goods.goods_id, goods.goods_name, stock.stock_count from user LEFT JOIN order ON order.user_id = user.user_id LEFT JOIN order_goods ON order_goods.order_id = order.order_id LEFT JOIN goods ON goods.goods_id = order_goods.goods_id LEFT JOIN stock ON stock.goods_id = goods.goods_id'; $list1 = Article::findBySql($map)->asArray()->all();
相關推薦:
以上是詳解YII2多表關聯的使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!