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.mzph.cn/news/612525.shtml

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

相关文章

Django 框架添加管理员,完成对普通用户信息管理

前情回顾&#xff1a;Django框架 完成用户登录注册 文章目录 1.创建管理员2.完善管理员功能2.1增加管理员登录功能2.2完善展示用户信息功能2.3完善修改用户信息功能2.4完善删除用户信息功能 1.创建管理员 一般管理员都是直接指定&#xff0c;不开放页面注册&#xff0c;可以直…

Mermaid 教程

Mermaid 教程 Mermaid 介绍 Mermaid 是一个用于生成流程图、时序图、甘特图等图表的 JavaScript 库。它使用类似于 Markdown 的文本语法&#xff0c;使得创建图表变得简单直观。以下是一个简单的 Mermaid 教程&#xff0c;介绍如何使用 Mermaid 创建流程图、时序图和甘特图。…

Qt中QByteArray之元素访问

访问QByteArray类对象中的某个元素主要有4种方式,分别为[]、at()、 data[]和constData[]。其中&#xff0c;[]和data]]方式为可读可写&#xff0c;at()和constData[]方式仅为可读。如果只是进行读操作&#xff0c;则通过at()和constData[]方式的访问速度最快&#xff0c;因为避…

wxWidgets实战:使用mpWindow绘制阻抗曲线

选择模型时&#xff0c;需要查看model的谐振频率&#xff0c;因此需要根据s2p文件绘制一张阻抗曲线。 如下图所示&#xff1a; mpWindow 左侧使用mpWindow&#xff0c;右侧使用什么&#xff1f; wxFreeChart https://forums.wxwidgets.org/viewtopic.php?t44928 https://…

【MMC子系统】四、MMC控制器驱动层

我的圈子&#xff1a; 高级工程师聚集地 我是董哥&#xff0c;高级嵌入式软件开发工程师&#xff0c;从事嵌入式Linux驱动开发和系统开发&#xff0c;曾就职于世界500强企业&#xff01; 创作理念&#xff1a;专注分享高质量嵌入式文章&#xff0c;让大家读有所得&#xff01; …

Keil编译生成的bin文件自动以版本号命名

Keil编译程序生成bin文件时&#xff0c;如何自动以版本号命名bin文件 一、目的二、方法三、实现过程1、脚本形式2、可执行文件形式 一、目的 Keil编译程序时&#xff0c;生成的Hex/Bin文件名字是根据Keil中工程配置里定的名字命名。通常代码里会有一个字段专门用来定义软件版本…

权限维持篇

一、Windows 1、 不死马权限维持 1.1 概述 <?php ignore_user_abort(); //关掉浏览器&#xff0c;PHP脚本也可以继续执行. set_time_limit(0);//通过set_time_limit(0)可以让程序无限制的执行下去 $interval 5; // 每隔*秒运行 do { $filename test.php; if(file_exi…

vue3.2引用unplugin-vue-components插入,解放开发中import组件

目录 前言引用unplugin-vue-components插件的优缺点优点缺点 unplugin-vue-components插件引入安装插件配置vite配置更新TypeScript配置使用代码位置 总结Q&A 前言 unplugin-vue-components是一个用于Vue.js项目的插件&#xff0c;特别适用于Vite和Webpack构建工具。它的主…

Java零基础教学文档第三篇:JDBC

今日新篇章 【JDBC】 【主要内容】 JDBC概述 使用JDBC完成添加操作 使用JDBC完成更新和删除 DBUtils的简单封装 使用JDBC完成查询 使用JDBC完成分页查询 常用接口详解 JDBC批处理 SQL注入问题 事务处理解决转账问题 连接池 使用反射对DBUtils再次的封装 BaseDAO的封…

第六篇 提升网页性能:深入解析HTTP请求优化策略(二)

文章目录 1 异步请求队列管理1.1 工作原理过程实现 1.2 优点1.3 示例 2 请求取消2.1. 工作原理2.2 优点2.3 实施细节2.4 axios取消请求2.5 fetch取消请求 HTTP请求优化是提高Web应用性能和用户体验的关键环节&#xff0c;异步请求队列管理和请求取消是其中的两个重要策略。以下…

Django报错处理

django.template.exceptions.TemplateDoesNotExist: django/forms/widgets/text.html django.template.exceptions.TemplateDoesNotExist: django/forms/widgets/number.html以上报错是pycharm中创建虚拟环境之后把原本自带的templates文件删除&#xff0c;重新在app01下面创建…

Unity Delaunay三角剖分算法 动态生成

Unity Delaunay三角剖分算法 动态生成 Delaunay三角剖分Delaunay三角剖分 定义Delaunay 边Delaunay 空圆特性 Delaunay 三角形Delaunay 最大化最小角特性 Delaunay 三角形特征Delaunay 算法Delaunay Lawson算法Delaunay Bowyer-Watson算法 Unity Delaunay三角剖分 应用Unity 工…

Linux——firewalld防火墙(二)

一、firewalld高级配置 1、IP地址伪装 地址伪装&#xff08;masquerade):通过地址伪装&#xff0c;NAT设备将经过设备的包转发到指定接收方&#xff0c;同时将通过的数据包的源地址更改为其自己的接口地址。当返回的数据包到达时&#xff0c;会将目的地址修改为原始主机的地址…

CMU15-445-Spring-2023-Project #2 - 前置知识(lec07-010)

Lecture #07_ Hash Tables Data Structures Hash Table 哈希表将键映射到值。它提供平均 O (1) 的操作复杂度&#xff08;最坏情况下为 O (n)&#xff09;和 O (n) 的存储复杂度。 由两部分组成&#xff1a; Hash Function和Hashing Scheme&#xff08;发生冲突后的处理&…

Red Hat 8.0 本地源配置方法

mkdir -p /tmp/yum mv /etc/yum.repos.d/* /tmp/yum mkdir -p /media/cdrom mount /dev/cdrom /media/cdrom df -Th生成yum配置 cat << EOF >> /etc/yum.repos.d/rhel8.repo [BaseOS] nameBaseOS baseurlfile:///media/cdrom/BaseOS enabled1 gpgcheck0[App…

【MySQL】MySQL版本8+ 窗口函数 Lead 的两种使用

力扣题 1、题目地址 1709. 访问日期之间最大的空档期 2、模拟表 表&#xff1a;UserVisits Column NameTypeuser_idintvisit_datedate 该表没有主键&#xff0c;它可能有重复的行该表包含用户访问某特定零售商的日期日志。 3、要求 假设今天的日期是 ‘2021-1-1’ 。 …

git拉取某远端分支创立为本地新分支

要从远程仓库拉取一个特定的分支并在本地创建一个新的分支&#xff0c;你可以使用以下步骤&#xff1a; 首先&#xff0c;确保你的本地仓库的远程分支信息是最新的。这可以通过执行git fetch命令完成。这个命令会从远程仓库获取最新的分支和数据&#xff0c;但不会自动合并或修…

jackson相关注解

JsonIgnoreProperties JsonIgnoreProperties(value { "prop1","prop2" })用来修饰Pojo类, 在序列化和反序列化的时候忽略指定的属性, 可以忽略一个或多个属性. JsonIgnoreProperties(ignoreUnknown true)用来修饰Pojo类, 在反序列化的时候忽略那…

神经辐射场(NeRF)概述

神经辐射场&#xff08;NeRF&#xff09;是一种用于三维场景重建的深度学习算法。它能够从一组稀疏的二维图片中重建出高质量的三维场景。 以下是对NeRF算法的原理和实现方法的详细解释&#xff1a; NeRF算法原理&#xff1a; 基本概念&#xff1a; NeRF算法基于光线追踪的原理…

Unified-IO 2 模型: 通过视觉、语言、音频和动作扩展自回归多模态模型。给大家提前预演了GPT5?

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…