thinkphp学习07-数据库的数据查询

单数据查询

单条数据查询,一般是一维数组

Db::table()中 table 必须指定完整数据表(包括前缀),如果配置了表前缀,Db::name()中可以忽略

如果希望只查询一条数据,可以使用 find()方法,需指定 where 条件;

public function index()
{$user = Db::table('tp_user')->where('id', 1)->find();//$user = Db::name('user')->where('id', 1)->find();return json($user);
}

在这里插入图片描述
Db::getLastSql()方法,可以得到最近一条 SQL 查询的原生语句;

public function index()
{$user = Db::table('tp_user')->where('id', 1)->find();echo print_r($user->array());echo "<br>";echo Db::getLastSql();
}

在这里插入图片描述
没有查询到任何值,则返回 null;

public function index()
{$user = Db::table('tp_user')->where('id', 110)->find();echo $user;
}

在这里插入图片描述
使用 findOrFail()方法同样可以查询一条数据,在没有数据时抛出一个异常;

public function index()
{$user = Db::table('tp_user')->where('id', 110)->findOrFail();echo $user;}

在这里插入图片描述
使用 findOrEmpty()方法也可以查询一条数据,但在没有数据时返回一个空数组

public function index()
{$user = Db::table('tp_user')->where('id', 110)->findOrEmpty();return json($user);
}

在这里插入图片描述

数据集查询

查询多条数据,一般是二维数组
想要获取多列数据,可以使用 select()方法

public function index()
{$users = Db::table('tp_user')->select();echo Db::getLastSql();echo "<br>";return json($users);
}

在这里插入图片描述
多列数据在查询不到任何数据时返回空数组,使用 selectOrFail()抛出异常

public function index()
{$users = Db::table('tp_user')->where("id",110)->selectOrFail();return json($users);
}

在这里插入图片描述
在 select()方法后再使用 toArray()方法,可以将数据集对象转化为数组

public function index()
{$users = Db::table('tp_user')->where("id",110)->select();dump($users);dump($users->toArray());
}

在这里插入图片描述

其它查询

通过 value()方法,可以查询指定字段的值(单个),没有数据返回 null

public function index()
{$username = Db::table('tp_user')->where("id", 2)->value("username");echo $username;$username = Db::table('tp_user')->where("id", 111)->value("username");echo $username;
}

在这里插入图片描述
可以指定 id 作为列值的索引

public function index()
{$user = Db::name('user')->column('username', 'id');return json($user);
}

在这里插入图片描述
如果处理的数据量巨大,成百上千那种,一次性读取有可能会导致内存开销过大,为了避免内存处理太多数据出错,可以使用 chunk()方法分批处理数据,比如,每次只处理 100 条,处理完毕后,再读取 100 条继续处理;
这里数据量不够100,每次取五条

public function index()
{Db::table('tp_user')->chunk(5, function ($users) {foreach ($users as $user) {dump($user);}echo 1;});
}

在这里插入图片描述
可以利用游标查询功能,可以大幅度减少海量数据的内存开销,它利用了 PHP 生成器特性。每次查询只读一行,然后再读取时,自动定位到下一行继续读取;

public function index()
{$cursor = Db::table('tp_user')->cursor();foreach ($cursor as $user) {dump($user);}
}

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/338837.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【JaveWeb教程】(17) MySQL数据库开发之 MySQL简介、安装、数据类型、SQL通用语法 详细代码示例讲解

目录 前言1. MySQL概述1.1 安装1.1.1 版本1.1.2 安装1.1.3 连接1.1.4 企业使用方式(了解) 1.2 数据模型1.3 SQL简介1.3.1 SQL通用语法1.3.2 分类 前言 在我们讲解SpringBootWeb基础知识(请求响应案例)的时候&#xff0c;我们讲到在web开发中&#xff0c;为了应用程序职责单一&…

Redis-Cluster 与 Redis 集群的技术大比拼

欢迎来到我的博客&#xff0c;代码的世界里&#xff0c;每一行都是一个故事 Redis-Cluster 与 Redis 集群的技术大比拼 前言概念与原理对比Redis-Cluster&#xff1a;基于哈希槽的分布式解决方案传统 Redis 集群&#xff1a;主从架构下的数据分片方式 搭建与配置的异同Redis-Cl…

Hive基础题-1

别看我&#xff0c;不看答案我也不会写 正因为不会写&#xff0c;所以才要每天一练 本地hive练习题 SET hive.exec.mode.local.autotrue; -- 默认 false SET hive.exec.mode.local.auto.inputbytes.max50000000; SET hive.exec.mode.local.auto.input.files.max5; -- 默认 4# …

centos7安装ES

1.JDK安装 因为我这里安装的ES版本是7.9.3 因为项目用的1.8的JDK, 7.9.3又兼容1.8&#xff0c;我在这装了1.8的JDK 支持一览表的IP 支持一览表 | Elastic 先将jdk的tar.gz 文件拷入系统 tar -zxvf jdk-8u351-linux-x64.tar.gz 解压压缩包 配置环境变量 vim /etc/profile …

Github 2024-01-11Go开源项目日报 Top9

根据Github Trendings的统计&#xff0c;今日(2024-01-11统计)共有9个项目上榜。根据开发语言中项目的数量&#xff0c;汇总情况如下&#xff1a; 开发语言项目数量Go项目9 Gin Web框架&#xff1a;高性能的Go HTTP框架 创建周期&#xff1a;3496 天开发语言&#xff1a;Go协…

视频监控录像服务器(中心录像服务器)功能详细介绍

目 录 一、概述 &#xff08;一&#xff09;定义 &#xff08;二&#xff09;视频监控中心录像服务器 二、存储策略服务 &#xff08;一&#xff09;存储策略配置 1、 录入页面 2、 选择需要进行录像的视频 3、批量选择多个通道号 4、其他关键参数…

代码随想录算法训练营第一天|数组理论基础、704二分查找、27移除元素

数组理论基础 一维数组 数组中的元素在内存空间中是连续的数组名与数组中第一个元素的地址相同&#xff08;一维数组&#xff09;数组的下标从0开始删除数组的元素其实是用后面的元素覆盖掉要删除的元素数组的长度不能改变 二维数组 二维数组是按照行存储的&#xff0c;也是…

【深度学习:数据标签 】什么是数据标签?【2024】终极指南

【深度学习&#xff1a;数据标签 】什么是数据标签&#xff1f;【2024】终极指南 了解数据标记什么是数据标注&#xff1f;数据标注在机器学习中的意义 数据标签如何工作&#xff1f;标记数据与未标记数据手动数据收集开源数据集合成数据生成数据标记过程确保数据安全与合规 数…

网络安全B模块(笔记详解)- Web信息收集

Web信息收集 1.通过Kali对服务器场景Linux进行Web扫描渗透测试(使用工具nikto,查看该命令的完整帮助文件),并将该操作使用命令中固定不变的字符串作为Flag提交; Flag:nikto -H 2.通过Kali对服务器场景Linux进行Web扫描渗透测试(使用工具nikto,扫描目标服务器8080端口,…

08、Kafka ------ 消息存储相关的配置-->消息过期时间设置、查看主题下的消息存活时间等配置

目录 消息存储相关的配置★ 消息的存储介绍★ 消息过期时间及处理方式演示&#xff1a;log.cleanup.policy 属性配置 ★ 修改指定主题的消息保存时间演示&#xff1a;将 test2 主题下的消息的保存时间设为10个小时1、先查看test2主题下的配置2、然后设置消息的保存时间3、然后再…

优化 ParamValidator,让编辑器Pycharm智能提示校验方法

目录 一、前置说明1、总体目录2、相关回顾3、本节目标 二、操作步骤1、项目目录2、代码实现3、测试代码4、日志输出 三、后置说明1、要点小结2、下节准备 一、前置说明 1、总体目录 《 pyparamvalidate 参数校验器&#xff0c;从编码到发布全过程》 2、相关回顾 基于 Valid…

美信科技盘古信息智能车间项目成功验收,打造电子元器件数字化工厂标杆

作为一家深耕于磁性元器件领域近二十年的制造企业&#xff0c;广东美信科技股份有限公司&#xff08;以下简称“美信科技”&#xff09;始终秉承着“为电磁赋能&#xff0c;创工业至美”的企业使命&#xff0c;为中国制造卓越发展贡献力量。在当今数字化时代&#xff0c;制造企…