搜尋
首頁php框架YIIyii2怎麼查詢數據

yii2怎麼查詢數據

Dec 09, 2019 pm 02:17 PM
yii2數據查詢

yii2怎麼查詢數據

#資料查詢

User::find()->all();    此方法返回所有数据;
User::findOne($id);   此方法返回 主键 id=1  的一条数据(举个例子); 
User::find()->where(['name' => '小伙儿'])->one();   此方法返回 ['name' => '小伙儿'] 的一条数据;
User::find()->where(['name' => '小伙儿'])->all();   此方法返回 ['name' => '小伙儿'] 的所有数据;
User::find()->orderBy('id DESC')->all();   此方法是排序查询;
User::findBySql('SELECT * FROM user')->all();  此方法是用 sql  语句查询 user 表里面的所有数据;
User::findBySql('SELECT * FROM user')->one();  此方法是用 sql  语句查询 user 表里面的一条数据;
User::find()->andWhere(['sex' => '男', 'age' => '24'])->count('id');   统计符合条件的总条数;
User::find()->one();    此方法返回一条数据;
User::find()->all();    此方法返回所有数据;
User::find()->count();    此方法返回记录的数量;
User::find()->average();    此方法返回指定列的平均值;
User::find()->min();    此方法返回指定列的最小值 ;
User::find()->max();    此方法返回指定列的最大值 ;
User::find()->scalar();    此方法返回值的第一行第一列的查询结果;
User::find()->column();    此方法返回查询结果中的第一列的值;
User::find()->exists();    此方法返回一个值指示是否包含查询结果的数据行;
User::find()->batch(10);  每次取 10 条数据 
User::find()->each(10);  每次取 10 条数据, 迭代查询

多表查詢:##

/* 多表联查 */
$model=new Customer();
$model->fiind()->join(‘LEFT JOIN‘,‘student‘,‘student.cid=customer.id‘)
            ->where(‘student.id‘=>\Yii::$app->user->id)
            ->andwhere(‘is_ok=1‘)
            ->one()

#關聯查詢

使用AR 方法也可以查詢資料表的關聯資料(如,選出表A的資料可以拉出表B的關聯資料)。有了 AR, 傳回的關聯資料連線就像連接關聯主表的 AR 物件的屬性一樣。

建立關聯關係後,透過 $customer->orders 可以取得 一個 Order 物件的陣列,該陣列代表目前客戶物件的訂單集。

定義關聯關係使用一個可以返回[[yii\db\ActiveQuery]] 物件的getter 方法, [[yii\db\ActiveQuery]]物件有關聯上下文的相關信息,因此可以只查詢關聯數據。

class Customer extends \yii\db\ActiveRecord
{
    public function getOrders()
    {
        // 客户和订单通过 Order.customer_id -> id 关联建立一对多关系
        return $this->hasMany(Order::className(), ['customer_id' => 'id']);
    }
}
 
class Order extends \yii\db\ActiveRecord
{
    // 订单和客户通过 Customer.id -> customer_id 关联建立一对一关系
    public function getCustomer()
    {
        return $this->hasOne(Customer::className(), ['id' => 'customer_id']);
    }
}

以上使用了[[yii\db\ActiveRecord::hasMany()]] 和 [[yii\db\ActiveRecord::hasOne()]]方法。以上兩例分別是關聯資料多對一關係和一對一關係的建模範例。如,一個客戶有很多訂單,一個訂單只歸屬一個客戶。兩個方法都有兩個參數並傳回[[yii\db\ActiveQuery]]物件。

建立關聯關係後,取得關聯資料和取得元件屬性一樣簡單, 執行以下對應getter方法即可:

// 取得客户的订单
$customer = Customer::findOne(1);
$orders = $customer->orders; // $orders 是 Order 对象数组

以上程式碼實際執行了以下兩個SQL 語句:

SELECT * FROM customer WHERE id=1;
SELECT * FROM order WHERE customer_id=1;

有時候需要在關聯查詢中傳遞參數,如不需要返回客戶全部訂單, 只需要返回購買金額超過設定值的大訂單, 透過以下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');
    }
}

聯合查詢

使用關聯式資料庫時,普遍要做的是連接多個資料表並明確運用各種JOIN 查詢。 JOIN SQL語句的查詢條件和參數,使用[[yii\db\ActiveQuery::joinWith()]] 可以重複使用已定義關係並呼叫而不是使用[[yii\db\ActiveQuery::join()]] 來實現目標。

// 查找所有订单并以客户 ID 和订单 ID 排序,并贪婪加载 "customer" 表
$orders = Order::find()->joinWith('customer')->orderBy('customer.id, order.id')->all();
// 查找包括书籍的所有订单,并以 `INNER JOIN` 的连接方式即时加载 "books" 表
$orders = Order::find()->innerJoinWith('books')->all();

以上方法[[yii\db\ActiveQuery::innerJoinWith()|innerJoinWith()]]是存取INNER JOIN類型的[[yii\db\ActiveQuery::joinWith()

#|joinWith()]]的捷徑。

可以連接一個或多個關聯關係,可以自由使用查詢條件到關聯查詢, 也可以嵌套連接關聯查詢。如:

// 连接多重关系
// 找出24小时内注册客户包含书籍的订单
$orders = Order::find()->innerJoinWith([
    'books',
    'customer' => function ($query) {
        $query->where('customer.created_at > ' . (time() - 24 * 3600));
    }
])->all();
// 连接嵌套关系:连接 books 表及其 author 列
$orders = Order::find()->joinWith('books.author')->all();

程式碼背後, Yii 先執行一 JOIN SQL 語句把滿足 JOIN SQL 語句查詢條件的主要模型查出, 然後為每個關係執行一條查詢語句, bing填入對應的關聯記錄。

[[yii\db\ActiveQuery::joinWith()|joinWith()]] 和[[yii\db\ActiveQuery::with()|with()]] 的差異在於前者連結主模型類別和關聯模型類別的資料表來檢索主模型, 而後者只查詢和檢索主模型類別。檢索主模型

由於這個差異,你可以套用只針對一條 JOIN SQL 語句起效的查詢條件。如,透過關聯模型的查詢條件過濾主模型,如前例, 可以使用關聯表的列來挑選主模型數據,

當使用[[yii\db\ActiveQuery::joinWith()|joinWith( )]] 方法時可以回應沒有歧義的列名。 In the above examples, we useitem.id and order.id to disambiguate the id column references 因為訂單表和項目表都包含 id 欄位。

當連線關聯關係時,關聯關係預設使用即時載入。你可以 透過傳參數 $eagerLoading 來決定在指定關聯查詢中是否使用即時載入。

預設 [[yii\db\ActiveQuery::joinWith()|joinWith()]] 使用左連線來連接關聯表。你也可以傳遞 $joinType 參數來客製化連線類型。你也可以使用 [[yii\db\ActiveQuery::innerJoinWith()|innerJoinWith()]]。

Yii2 分頁

控制器CommentController 裡面的任何一個方法,在這裡我的方法是actionComment();

use yii\data\Pagination;
use app\models\Comment;
  public function actionComment(){
       $data = Comment::find()->andWhere(['id' => '10']);
       $pages = new Pagination(['totalCount' =>$data->count(), 'pageSize' => '2']);
       $model = $data->offset($pages->offset)->limit($pages->limit)->all();
       
       return $this->render('comment',[
             'model' => $model,
             'pages' => $pages,
       ]);
  }

#view裡面的程式碼

<?php
use yii\widgets\LinkPager;
?>
      foreach($model as $key=>$val)
      {
           这里就是遍历数据
      }
      <?= LinkPager::widget([&#39;pagination&#39; => $pages]); ?>

in() 操作

SELECT * FROM `categ_price` WHERE `id` IN (9, 11)

$categ_price_id=[9>1,11=>3]
  $categPriceModel= \common\models\CategPrice::find()->where([&#39;id&#39; =>array_keys($categ_price_id)])->all();
  #>where([&#39;id&#39; => [1, 2, 3]])

not in() 操作

SELECT * FROM `shop` WHERE (status=1) AND (`id` NOT IN (88, 93))

$shopModel= Shop::find()->where(&#39;status=1&#39;)->andWhere([&#39;not in&#39;,&#39;id&#39;,[88,98]])->all();

PHP中文網,有大量免費的

Yii入門教學,歡迎大家學習!

以上是yii2怎麼查詢數據的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
YII的當前狀態:查看其受歡迎程度YII的當前狀態:查看其受歡迎程度Apr 13, 2025 am 12:19 AM

yiiremainspularbutislessfavoredthanlaravel,withabout14kgithubstars.itexcelsinperformanceandactiverecord,buthasasteperlearningcurveandasmallerecosystem.it'sidealfordealfordealfordEvelforkerfordEvelforkerplovelfordEvelforkerporporporporporporporporizatized efferporization effervastecoseposevastecosystecystemystem。

yii:解釋的關鍵特徵和優勢yii:解釋的關鍵特徵和優勢Apr 12, 2025 am 12:15 AM

Yii是一個高性能的PHP框架,其獨特之處在於組件化架構、強大的ORM和出色的安全性。 1.組件化架構讓開發者能靈活拼裝功能。 2.強大的ORM簡化了數據操作。 3.內置多種安全功能,確保應用安全。

Yii的架構:MVC等Yii的架構:MVC等Apr 11, 2025 pm 02:41 PM

Yii框架採用MVC架構,並通過組件、模塊等增強其靈活性和擴展性。 1)MVC模式將應用邏輯分為模型、視圖和控制器。 2)Yii的MVC實現通過動作細化請求處理。 3)Yii支持模塊化開發,提升代碼組織和管理。 4)使用緩存和數據庫查詢優化可提升性能。

YII 2.0深水潛水:性能調整與優化YII 2.0深水潛水:性能調整與優化Apr 10, 2025 am 09:43 AM

提升Yii2.0应用性能的策略包括:1.数据库查询优化,使用QueryBuilder和ActiveRecord选择特定字段和限制结果集;2.缓存策略,合理使用数据、查询和页面缓存;3.代码级优化,减少对象创建和使用高效算法。通过这些方法,可以显著提升Yii2.0应用的性能。

YII RESTFUL API開發:最佳實踐和身份驗證YII RESTFUL API開發:最佳實踐和身份驗證Apr 09, 2025 am 12:13 AM

在Yii框架中開發RESTfulAPI可以通過以下步驟實現:定義控制器:使用yii\rest\ActiveController來定義資源控制器,如UserController。配置認證:通過添加HTTPBearer認證機制來確保API的安全性。實現分頁和排序:使用yii\data\ActiveDataProvider來處理複雜的業務邏輯。錯誤處理:配置yii\web\ErrorHandler來定制錯誤響應,如認證失敗時的處理。性能優化:利用Yii的緩存機制來優化頻繁訪問的資源,提高API性能。

高級YII框架:掌握組件和擴展高級YII框架:掌握組件和擴展Apr 08, 2025 am 12:17 AM

在Yii框架中,組件是可重用的對象,擴展是通過Composer添加的插件。 1.組件通過配置文件或代碼實例化,使用依賴注入容器提高靈活性和可測試性。 2.擴展通過Composer管理,快速增強應用功能。使用這些工具可以提升開發效率和應用性能。

yii主題和模板:創建美麗而響應式的接口yii主題和模板:創建美麗而響應式的接口Apr 07, 2025 am 12:03 AM

Yii框架的Theming和Templating通過主題目錄和視圖、佈局文件實現網站風格和內容生成:1.Theming通過設置主題目錄管理網站樣式和佈局,2.Templating通過視圖和佈局文件生成HTML內容,3.使用Widget系統嵌入複雜UI組件,4.優化性能和遵循最佳實踐提升用戶體驗和開發效率。

YII面試問題:ACE您的PHP框架面試YII面試問題:ACE您的PHP框架面試Apr 06, 2025 am 12:20 AM

在準備Yii框架的面試時,你需要了解以下關鍵知識點:1.MVC架構:理解模型、視圖和控制器的協同工作。 2.ActiveRecord:掌握ORM工具的使用,簡化數據庫操作。 3.Widgets和Helpers:熟悉內置組件和輔助函數,快速構建用戶界面。掌握這些核心概念和最佳實踐將幫助你在面試中脫穎而出。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

DVWA

DVWA

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

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用