6原生SQL查询
未知
2021-07-04 11:04:10
0

Db类支持原生SQL查询操作,主要包括下面两个方法:

V6.0.3+版本开始,原生查询仅支持Db类操作,不支持在模型中调用原生查询方法(包括queryexecute方法)。

query方法

query方法用于执行SQL查询操作,返回查询结果数据集(数组)。

使用示例:

Db::query("select * from think_user where status=:id", ['id' => 1]);
复制

如果你当前采用了分布式数据库,并且设置了读写分离的话,query方法默认是在读服务器执行,而不管你的SQL语句是什么。

如果希望从主库读取,可以使用

Db::query("select * from think_user where status=:id", ['id' => 1], true);
复制

execute方法

execute用于更新和写入数据的sql操作,如果数据非法或者查询错误则返回false,否则返回影响的记录数。

使用示例:

Db::execute("update think_user set name='thinkphp' where status=1");
复制

如果你当前采用了分布式数据库,并且设置了读写分离的话,execute方法始终是在写服务器执行,而不管你的SQL语句是什么。

参数绑定

支持在原生查询的时候使用参数绑定,包括问号占位符或者命名占位符,例如:

Db::query("select * from think_user where id=? AND status=?", [8, 1]);
// 命名绑定
Db::execute("update think_user set name=:name where status=:status", ['name' => 'thinkphp', 'status' => 1]);
复制

注意不支持对表名使用参数绑定

上一篇:6子查询

下一篇:6查询事件

相关内容

2024年全国结婚登记61...
2024年全国结婚登记610.6万对显示现代婚姻市场稳定趋势,反映...
2025-02-10 05:00:38
MySQL触发器最佳实践与...
摘要: 本文介绍了MySQL触发器的最佳实践和案例分析,包括明确...
2025-02-09 12:46:40
触发器与事件处理程序的比较
触发器与事件处理程序是用于处理特定事件的两种机制。触发器是数据库对...
2025-02-09 12:23:36
MySQL触发器实例:订单...
MySQL触发器实例:通过订单处理,展示如何利用触发器自动更新库存...
2025-02-09 12:00:46
MySQL索引的最佳实践策...
MySQL索引最佳实践:明确需求,合理设计索引类型,避免过度索引,...
2025-02-09 11:23:43
优化MySQL查询性能的关...
摘要: 本文介绍了MySQL中索引的概念、作用及创建、使用和优化...
2025-02-09 11:00:40

热门资讯

tp6开发规范 命名规范 请理解并尽量遵循以下命名规范,可以减少在开发过程中出现不必要的错误。 ThinkPHP6....
6高级查询 快捷查询 快捷查询方式是 一种多字段相同查询条件 的简化写法,可以进一步简化查询条件的写法,在多个字...
tp6多应用提示控制器不存在:... 第一个情况是没有使用composer安装扩展。 如果要使用多应用模式, 你需要win+r,cmd指针...
6配置 配置目录 单应用模式 对于单应用模式来说,配置文件和目录很简单,根目录下的 config 目录下面就...
6异常处理 和PHP默认的异常处理不同,ThinkPHP抛出的不是单纯的错误信息,而是一个人性化的错误页面。 异...
6swoole 本篇内容主要讲述了最新的 think-swoole 扩展的使用。目前仅支持Linux环境或者MacO...
6助手函数 助手函数 系统为一些常用的操作方法封装了助手函数,便于使用,包含如下: 助手函数 描述 abort ...
6查询表达式 查询表达式 查询表达式支持大部分的SQL查询语法,也是 ThinkPHP 查询语言的精髓,查询表达式...
6路由参数 路由参数 路由分组及规则定义支持指定路由参数,这些参数主要完成路由匹配检测以及后续行为。 路由参数可...
6查询 模型查询和数据库查询方法的区别主要在于,模型中的查询的数据在获取的时候会经过获取器的处理,以及更加对...