這篇文章主要介紹了Yii2.0表關聯查詢的方法,結合實例形式分析了Yii中關聯查詢的實現方法與相關使用技巧,需要的朋友可以參考下
本文實例講述了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'); } }
以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!
相關推薦:
以上是對於Yii2.0表關聯查詢的分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

要保護應用免受與會話相關的XSS攻擊,需採取以下措施:1.設置HttpOnly和Secure標誌保護會話cookie。 2.對所有用戶輸入進行輸出編碼。 3.實施內容安全策略(CSP)限制腳本來源。通過這些策略,可以有效防護會話相關的XSS攻擊,確保用戶數據安全。

优化PHP会话性能的方法包括:1.延迟会话启动,2.使用数据库存储会话,3.压缩会话数据,4.管理会话生命周期,5.实现会话共享。这些策略能显著提升应用在高并发环境下的效率。

theSession.gc_maxlifetimesettinginphpdeterminesthelifespanofsessiondata,setInSeconds.1)它'sconfiguredinphp.iniorviaini_set().2)abalanceisesneededeededeedeedeededto toavoidperformance andunununununexpectedLogOgouts.3)

在PHP中,可以使用session_name()函數配置會話名稱。具體步驟如下:1.使用session_name()函數設置會話名稱,例如session_name("my_session")。 2.在設置會話名稱後,調用session_start()啟動會話。配置會話名稱可以避免多應用間的會話數據衝突,並增強安全性,但需注意會話名稱的唯一性、安全性、長度和設置時機。

會話ID應在登錄時、敏感操作前和每30分鐘定期重新生成。 1.登錄時重新生成會話ID可防會話固定攻擊。 2.敏感操作前重新生成提高安全性。 3.定期重新生成降低長期利用風險,但需權衡用戶體驗。

在PHP中設置會話cookie參數可以通過session_set_cookie_params()函數實現。 1)使用該函數設置參數,如過期時間、路徑、域名、安全標誌等;2)調用session_start()使參數生效;3)根據需求動態調整參數,如用戶登錄狀態;4)注意設置secure和httponly標誌以提升安全性。

在PHP中使用會話的主要目的是維護用戶在不同頁面之間的狀態。 1)會話通過session_start()函數啟動,創建唯一會話ID並存儲在用戶cookie中。 2)會話數據保存在服務器上,允許在不同請求間傳遞數據,如登錄狀態和購物車內容。

如何在子域名間共享會話?通過設置通用域名的會話cookie實現。 1.在服務器端設置會話cookie的域為.example.com。 2.選擇合適的會話存儲方式,如內存、數據庫或分佈式緩存。 3.通過cookie傳遞會話ID,服務器根據ID檢索和更新會話數據。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3漢化版
中文版,非常好用

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),