搜尋
首頁php框架ThinkPHPThinkPHP資料庫操作之聚合查詢、時間查詢、進階查詢

以下由thinkphp教學欄位來介紹ThinkPHP資料庫操作之聚合查詢、時間查詢、進階查詢,希望對需要的朋友有幫助!

聚合查詢

在應用程式中我們經常會用到一些統計數據,例如當前所有(或滿足某些條件)的用戶數、所有使用者的最大積分、使用者的平均成績等等,ThinkPHP為這些統計運算提供了一系列內建的方法,包括:

##用法範例:

取得使用者數:

Db::table('think_user')->count();
// 助手函数
db('user')->count();
或根據欄位統計:

Db::table('think_user')->count('id');
// 助手函数
db('user')->count('id');
取得使用者的最大積分:

Db::table('think_user')->max('score');
// 助手函数
db('user')->max('score');
取得積分大於0的使用者的最小積分:

Db::table('think_user')->where('score>0')->min('score');
// 助手函数
db('user')->where('score>0')->min('score');
取得使用者的平均積分:

Db::table('think_user')->avg('score');
// 助手函数
db('user')->avg('score');
統計使用者的總成績:

Db::table('think_user')->sum('score');
// 助手函数
db('user')->sum('score');

時間查詢

時間比較

#使用where 方法where

方法支援時間比較,例如:

// 大于某个时间
where('create_time','> time','2016-1-1');
// 小于某个时间
where('create_time','<span style="font-size: 16px">第三個參數可以傳入任何有效的時間表達式,會自動識別你的時間欄位類型,支援的時間類型包括timestamps 、 datetime 、 date 和int 。 <strong><span style="color: rgba(0, 128, 128, 1)"></span></strong></span>使用whereTime 方法<p></p><p></p>#whereTime方法提供了日期和時間欄位的快速查詢,範例如下:<p></p><pre class="brush:php;toolbar:false">// 大于某个时间
db('user')    ->whereTime('birthday', '>=', '1970-10-1')    ->select();
// 小于某个时间
db('user')    ->whereTime('birthday', 'select();
// 时间区间查询
db('user')    ->whereTime('birthday', 'between', ['1970-10-1', '2000-10-1'])    ->select();
// 不在某个时间区间
db('user')    ->whereTime('birthday', 'not between', ['1970-10-1', '2000-10-1'])    ->select();

時間表達式

#也提供了更方便的時間表達式查詢,例如:

// 获取今天的博客
db('blog')    ->whereTime('create_time', 'today')    ->select();
// 获取昨天的博客
db('blog')    ->whereTime('create_time', 'yesterday')    ->select();
// 获取本周的博客
db('blog')    ->whereTime('create_time', 'week')    ->select();
// 获取上周的博客
db('blog')    ->whereTime('create_time', 'last week')    ->select();
// 获取本月的博客
db('blog')    ->whereTime('create_time', 'month')    ->select();
// 获取上月的博客
db('blog')    ->whereTime('create_time', 'last month')    ->select();
// 获取今年的博客
db('blog')    ->whereTime('create_time', 'year')    ->select();
// 获取去年的博客
db('blog')    ->whereTime('create_time', 'last year')    ->select();
如果查詢當天、本週、本月和今年的時間,還可以簡化為:
// 获取今天的博客
db('blog')    ->whereTime('create_time', 'd')    ->select();
// 获取本周的博客
db('blog')    ->whereTime('create_time', 'w')    ->select();
// 获取本月的博客
db('blog')    ->whereTime('create_time', 'm')    ->select();
// 获取今年的博客
db('blog')    ->whereTime('create_time', 'y')    ->select();
V5.0.5 版本開始,還可以使用下面的方式進行時間查詢
// 查询两个小时内的博客
db('blog')    ->whereTime('create_time','2 hours')    ->select();

進階查詢

#快速查詢

快捷查詢方式是一種多字段相同查詢條件

的簡化寫法,可以進一步簡化查詢條件的寫法,在多個字段之間用| 分割表示OR查詢,用& 分割表示AND查詢,可以實作下面的查詢,例如:

Db::table('think_user')    ->where('name|title','like','thinkphp%')    ->where('create_time&update_time','>',0)    ->find();
產生的查詢SQL是:
SELECT * FROM `think_user` WHERE ( `name` LIKE 'thinkphp%' OR `title` LIKE 'thinkphp%') AND ( `create_time` > 0 AND `update_time` > 0 ) LIMIT 1
  

快速查詢支援所有的查詢表達式。

區間查詢

#區間查詢是一種相同欄位多個查詢條件的簡化寫法,例如:

Db::table('think_user')    ->where('name',['like','thinkphp%'],['like','%thinkphp'])    ->where('id',['>',0],['',10],'or')    ->find();
產生的SQL語句為:

SELECT * FROM `think_user` WHERE ( `name` LIKE 'thinkphp%' AND `name` LIKE '%thinkphp') AND ( `id` > 0 OR `id`  10 ) LIMIT 1

  

區間查詢的查詢條件必須使用陣列定義方式,支援所有的查詢表達式。

下面的查詢方式是錯誤的:

Db::table('think_user')    ->where('name',['like','thinkphp%'],['like','%thinkphp'])    ->where('id',5,['',10],'or')    ->find();

批次查詢

可以進行多個條件的批次條件查詢定義,例如:

Db::table('think_user'->'name' => ['like','thinkphp%'],
        'title' => ['like','%thinkphp'],
        'id' => ['>',0],
        'status'=> 1->

產生的SQL語句為:

SELECT * FROM `think_user` WHERE `name` LIKE 'thinkphp%' AND `title` LIKE '%thinkphp' AND `id` > 0 AND `status` = '1'

閉包查詢

Db::table('think_user')->select(function($query){    $query->where('name','thinkphp')            ->whereOr('id','>',10);
});
產生的SQL語句為:

SELECT * FROM `think_user` WHERE `name` = 'thinkphp' OR `id` > 10

使用Query對象查詢

也可以事先封裝Query對象,並傳入select方法,例如:

$query = new \think\db\Query;$query->name('user')    ->where('name','like','%think%')    ->where('id','>',10)    ->limit(10);
Db::select($query);

  如果使用Query 物件的話, select 方法之前呼叫的任何的鍊式運算都是無效。

混合查詢

#可以結合前面提到的所有方式進行混合查詢,例如:

Db::table('think_user')    ->where('name',['like','thinkphp%'],['like','%thinkphp'])    ->where(function($query){        $query->where('id',['',100],'or');
    })    ->select();

產生的SQL語句是:

SELECT * FROM `think_user` WHERE ( `name` LIKE 'thinkphp%' AND `name` LIKE '%thinkphp') AND ( `id`  100 )

#字串條件查詢###############對於一些實在複雜的查詢,也可以直接使用原生SQL語句進行查詢,例如:###
Db::table('think_user')    ->where('id > 0 AND name LIKE "thinkphp%"')    ->select();
###為了安全起見,我們可以對字串查詢條件使用參數綁定,例如:###
Db::table('think_user')    ->where('id > :id AND name LIKE :name ',['id'=>0, 'name'=>'thinkphp%'])    ->select();
###V5. 0.4 開始,ThinkPHP支援對同一個欄位多次呼叫查詢條件,例如:###
Db::table('think_user')    ->where('name','like','%think%')    ->where('name','like','%php%')    ->where('id','in',[1,5,80,50])    ->where('id','>',10)    ->find();
#########快速方法( V5.0.5 )##########

V5.0.5 版本開始新增了一系列快速方法,用於簡化查詢,包括:

以上是ThinkPHP資料庫操作之聚合查詢、時間查詢、進階查詢的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:cnblogs。如有侵權,請聯絡admin@php.cn刪除
ThinkPHP內置測試框架的關鍵功能是什麼?ThinkPHP內置測試框架的關鍵功能是什麼?Mar 18, 2025 pm 05:01 PM

本文討論了ThinkPHP的內置測試框架,突出了其關鍵功能(例如單元和集成測試),以及它如何通過早期的錯誤檢測和改進的代碼質量來增強應用程序可靠性。

如何使用ThinkPHP來構建實時股票市場數據源?如何使用ThinkPHP來構建實時股票市場數據源?Mar 18, 2025 pm 04:57 PM

文章討論了使用ThinkPHP進行實時股票市場數據提要,重點是設置,數據準確性,優化和安全措施。

在無服務器體系結構中使用ThinkPHP的關鍵注意事項是什麼?在無服務器體系結構中使用ThinkPHP的關鍵注意事項是什麼?Mar 18, 2025 pm 04:54 PM

本文討論了在無服務器體系結構中使用ThinkPHP的關鍵注意事項,專注於性能優化,無狀態設計和安全性。它突出了諸如成本效率和可擴展性之類的收益,但也應對挑戰

如何在ThinkPHP微服務中實現服務發現和負載平衡?如何在ThinkPHP微服務中實現服務發現和負載平衡?Mar 18, 2025 pm 04:51 PM

本文討論了在ThinkPHP微服務中實施服務發現和負載平衡,重點是設置,最佳實踐,集成方法和推薦工具。[159個字符]

ThinkPHP依賴性注入容器的高級功能是什麼?ThinkPHP依賴性注入容器的高級功能是什麼?Mar 18, 2025 pm 04:50 PM

ThinkPHP的IOC容器提供了高級功能,例如懶惰加載,上下文綁定和方法注入PHP App中有效依賴性管理的方法。Character計數:159

如何使用ThinkPHP來構建實時協作工具?如何使用ThinkPHP來構建實時協作工具?Mar 18, 2025 pm 04:49 PM

本文討論了使用ThinkPHP來構建實時協作工具,重點關注設置,Websocket集成和安全性最佳實踐。

使用ThinkPHP來構建SaaS應用程序的主要好處是什麼?使用ThinkPHP來構建SaaS應用程序的主要好處是什麼?Mar 18, 2025 pm 04:46 PM

ThinkPHP具有輕巧的設計,MVC架構和可擴展性。它通過各種功能提高可擴展性,加快開發並提高安全性。

如何使用ThinkPHP和RabbitMQ構建分佈式任務隊列系統?如何使用ThinkPHP和RabbitMQ構建分佈式任務隊列系統?Mar 18, 2025 pm 04:45 PM

本文概述了使用ThinkPhp和RabbitMQ構建分佈式任務隊列系統,重點是安裝,配置,任務管理和可擴展性。關鍵問題包括確保高可用性,避免常見的陷阱,例如不當

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

熱工具

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

MantisBT

MantisBT

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

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具