ThinkPHP中框架查詢

来源:https://www.cnblogs.com/shineguang/archive/2019/07/06/11144781.html
-Advertisement-
Play Games

1.查詢多條數據 1.1靜態調用all方法或者select方法 1.2動態調用all方法或者select方法 註:all方法或者select方法返回的是一個包含模型對象的二維數組或者空數組select方法和All方法的應用:[obj, obj] 2.查詢一條數據 2.1靜態調用get方法或者find ...


1.查詢多條數據

         1.1靜態調用all方法或者select方法

// 獲取所有數據 all 和 select

$list = User::all();

// 根據主鍵獲取多個數據all 和 select   where id in (1,2,3)

$list = User::all('1,2,3');

$list = User::all([1,2,3]);

//或者使用數組查詢(只能用all不能用select)   where status = 1

$list = User::all(['status'=>1]);

              1.2動態調用all方法或者select方法

$user = new User();

//查詢所有數據all 和 select

$list = $user->select();

//根據主鍵查詢多條數據all 和 select

$list = $user->select('1,2,3');

$list = $user->select([1,2,3]);

//或者使用數組查詢(只能用all不能用select)

$list = $user->all(['status'=>1]);

           註:all方法或者select方法返回的是一個包含模型對象的二維數組或者空數組select方法和All方法的應用:[obj, obj]

2.查詢一條數據

          2.1靜態調用get方法或者find方法

//取出主鍵為1的數據  where id = 1

$user = \app\admin\model\User::get(1);

$user = \app\admin\model\User::find(1);

//使用數組查詢(非主鍵欄位),只能用get不能用find   where name = 'thinkphp'

$user = User::get(['name' => 'thinkphp']);

//取出第一條數據,只能用find不能用get

$user = User::find();

              2.2動態調用get方法或者find方法

$user = new User();

//取出主鍵為1的數據

$info = $user->find(1);

$info = $user->get(1);

//使用數組查詢(非主鍵欄位),只能用get不能用find

$info = $user->get(['name' => 'thinkphp']);

//取出第一條數據,只能用find不能用get

$info = $user->find();

             註:get或者find方法返回的是當前模型的對象實例或者null返回的模型對象,可以直接當做數組使用,也可以調用toArray() 直接轉化為數組。find方法和Get方法的應用:

3.其他查詢方法

           3.1where方法

$info = User::where('id','=','1')->find();

$info = User::where('id','1')->find();

$info = User::where('name','like','%thinkphp%')->select();

               3.2鏈式操作

$model = new Address();

$model->field('id
name')->select(); //指定要查詢的欄位,原生sql中select後面的欄位

$model->order('id desc,time desc')->select(); //相當於原生sql中的order by

$model->limit(3)->select(); //相當於原生sql中的limit條件

$model->limit(0,3)->select(); 

$model->limit('0,3')->select(); 

$model->group('cate_id')->select();  //相當於原生sql中的group by

$model->having('id>3')->select();  //相當於原生sql中的having條件

$model->alias('a')->join('think_user_type t','a.id=t.user_id', 'left')->select(); //alias方法設置別名,join方法連表查詢

               3.3聚合查詢

            在模型中也可以調用資料庫的聚合方法進行查詢

            3.4數據欄位查詢

 

查詢一條記錄的一個欄位的值
Goods::where(‘id’, 2)->value(‘goods_name’);
查詢多條記錄的一個欄位的值,返回一個一維索引數組
Goods::where(‘id’, ‘GT’, 2)->column(‘goods_name’);
查詢多條記錄的一個欄位的值,以id欄位值作為數組索引
Goods::where(‘id’, ‘GT’, 2)->column(‘goods_name’, ‘id’);

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • [TOC] 一、I/O模型介紹 為了更好地瞭解I/O模型,我們需要事先回顧下:同步、非同步、阻塞、非阻塞 同步(synchronous) I/O和非同步(asynchronous) I/O,阻塞(blocking) I/O和非阻塞(non blocking)I/O分別是什麼,到底有什麼區別?這個問題其實 ...
  • 一、新增 1、使用save() 2、使用createCommand 原生sql 3、使用createCommand insert 4、批量插入 二、刪除 1、使用delete() 2、使用deleteAll()批量刪除 3、使用createCommand delete() 4、使用createCom ...
  • 相似基因 題目 【題目描述】 大家都知道,基因可以看作一個鹼基對序列。它包含了4種核苷酸,簡記作A,C,G,T。生物學家正致力於尋找人類基因的功能,以利用於診斷疾病和發明藥物。 在一個人類基因工作組的任務中,生物學家研究的是:兩個基因的相似程度。因為這個研究對疾病的治療有著非同尋常的作用。 兩個基因 ...
  • 1、BeanFactory 介紹 1.1 首先什麼是Bean? 1、Bean在Spring技術中是基於組件 2、他是Spring容器管理的最基本最常見的單元。在spring的應用場合中,bean可以是數據源、java的普通類 3、其實例保存在Spring的容器中,這種方式也是spring的核心思想所 ...
  • 1、Spring主要用到兩種設計模式 1.1 工廠模式 Spring容器就是實例化和管理全部Bean的工廠。 工廠模式可以將Java對象的調用者從被調用者的實現邏輯中分離出來。 調用者只關心被調用者必須滿足的某種規則,這裡的規則我們可以看做是介面,而不必關心實例的具體實現過程,具體實現由Bean工廠 ...
  • float為什麼比int表示的範圍廣? 什麼是單精度和雙精度? float表示小數的時候為什麼會有精度丟失? 帶著這幾個問題,我們來探究下java中float類型在電腦的表示形式。 java中int占用4個位元組,float也是占用4個位元組,但是為什麼float表示的範圍要比int大呢,因為兩者在計 ...
  • emmm,沒有啥前言 玩過SpringBoot的都知道,SpringBoot啟動的時候,預設會在控制台列印SpringBoot字樣和當前版本。 可是腦洞奇大的程式員怎麼可能就這麼拘泥於正常banner呢? 怎麼騷怎麼來是吧~ 具體說明用法,我就不一一舉例了,網上有很多設置banner的方案。 我一般 ...
  • 電腦網路基礎 1. 什麼是互聯網協議 一系列統一的標準,這些標準稱之為互聯網協議,互聯網的本質就是一系列的協議,總稱為‘互聯網協議’(Internet Protocol Suite)。 互聯網協議的功能:定義電腦如何接入internet,以及接入internet的電腦通信的標準。 2. osi ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...