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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...