PHP:ThinkPHP5数据库操作增删改查-Db类

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL DuckDB 分析主实例,集群系列 8核16GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: PHP:ThinkPHP5数据库操作增删改查-Db类

项目文件目录

project/
    -app
    -conf

1、数据库配置

方式一 配置文件

conf/database.php

<?php
return [
    'type'            => 'mysql',
    'hostname'        => '127.0.0.1',
    'database'        => 'root',
    'username'        => 'root',
    'password'        => '123456',
    'hostport'        => '3306',
    'charset'         => 'utf8'
];

方式二:控制函数

app\index\controller\Index.php

namespace app\index\controller;
use think\Db;
class Index
{
    public function index()
    {
        $db = Db::connect([
            'type' => 'mysql',
            'hostname' => '127.0.0.1',
            'database' => 'root',
            'username' => 'root',
            'password' => '123456',
            'hostport' => '3306',
            'charset' => 'utf8'
        ]);
        dump($db);
    }
}

方式三 DSN方式 Data Source Name

$db = Db::connect('mysql://root:123456@127.0.0.1:3306/demo#utf8');

方式四 从读取配置

conf/config.php

<?php
return [
    'db_config' => [
        'type'            => 'mysql',
        'hostname'        => '127.0.0.1',
        'database'        => 'root',
        'username'        => 'root',
        'password'        => '123456',
        'hostport'        => '3306',
        'charset'         => 'utf8'
    ]
];

app\index\controller\Index.php

$db = Db::connect('db_config');
// 或者
use  think/Config;
$db = Db::connect(Config::get('db_config'));

2、获取数据表对象

$bd = Db::table('pre_user')  # Db是单例模式
$bd = Db::name('user')  # 会自动添加前缀
# 助手函数 db 每次调用实例化false取消每次实例化
$bd = db('pre_user', [], false)  

3、查询数据

// 检查数据库配置
dump(config('database'));
// 使用sql语句查询
$res = Db::query("select * from student");
$res = Db::query("select * from student where id=?", [1]);
// 插入数据 返回影响条数
$res =Db::execute("insert into student set name=?, age=?", ['Tom',23]);
// select 返回所有记录 二维数组 []
$res = Db::table('student')->select();
// column 返回所有列记录 二维数组 NULL
# 如果存在第二个参数,为key值
$res = Db::table('student')->column('age', 'name');
// find 返回一条记录 一维数组 NULL
$res = Db::table('student')->find();
// value 返回一条记录中的某个字段 NULL
$res = Db::table('student')->value('name');

4、插入数据

$db = Db::table('student');
#insert 返回值是影响记录的行数,插入数
$res = $db->insert([
            'name' => 'Tom',
            'age' => 23
        ]);
#insetGetId 返回值插入数据的自增id
$res = $db->insertGetId([
            'name' => 'Tom',
            'age' => 23
        ]);
#insertAll 返回插入数据成功的行数
$data = [];
for ($i=0; $i<10; $i++)
{
    $data[] = [
        'name' => "Tom{$i}",
        'age' => 23
    ];
};
$res = $db->insertAll($data);

5、更新数据

# update 更新多个字段 返回影响行数
$res = $db->where([
        'id'=>1
    ])->update([
        'name'=> '王小二'
    ]);
# setField 更新一个字段 返回影响行数
$res = $db->where([
        'id' => 1
    ])->setField('name', '王大锤');
# setInc 自增 返回影响行数
$res = $db->where([
        'id' => 1
    ])->setInc('age');
# setDec 自减 返回影响行数
$res = $db->where([
        'id' => 1
    ])->setDec('age');

6、删除数据

# 条件删除,返回影响行数
$res = $db->where(
        ['id'=>1]
    )->delete();
# 传入主键删除 返回影响行数
$res = $db->delete(2);
# 清空数据
$res = $db->where('1=1')->delete();

7、条件构造器

buildSql();返回SQL语句

where(‘字段名’,‘表达式’,‘查询条件’);

表达式

含义

EQ、=

等于(=)

NEQ、<>

不等于(<>)

GT、>

大于(>)

EGT、>=

大于等于(>=)

LT、<

小于(<)

ELT、<=

小于等于(<=)

LIKE

模糊查询

[NOT] BETWEEN

(不在)区间查询

[NOT] IN

(不在)IN 查询

[NOT] NULL

查询字段是否(不)是NULL

[NOT] EXISTS

EXISTS查询

EXP

表达式查询,支持SQL语法

> time

时间比较

< time

时间比较

between time

时间比较

notbetween time

时间比较


示例

$db->where()->buildSql();
# 构造条件
$res = $db
    ->where('id', 'in', [1, 2, 3])
    ->whereOr('id', '<', '4')
    ->buildSql();
// string(62) "( SELECT * FROM `student` WHERE  `id` IN (1,2,3) OR `id` < 4 )"

链式操作

$res = Db::table('user')
    ->where('id', '>', 10)
    ->field('name', 'id')
    ->order('id DESC')
    // ->limit(3, 5)
    // ->page(3, 5)  // limit((3-1)*5, 5)
    ->group('`group`')
    ->select();
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
存储 SQL 关系型数据库
PHP与数据库交互:从基础到进阶
【10月更文挑战第9天】在编程的世界里,数据是流动的血液,而数据库则是存储这些珍贵资源的心脏。PHP作为一门流行的服务器端脚本语言,其与数据库的交互能力至关重要。本文将带你从PHP与数据库的基本连接开始,逐步深入到复杂查询的编写和优化,以及如何使用PHP处理数据库结果。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供宝贵的知识和技巧,让你在PHP和数据库交互的道路上更加从容不迫。
|
NoSQL 关系型数据库 MySQL
不是 PHP 不行了,而是 MySQL 数据库扛不住啊
【9月更文挑战第8天】这段内容讨论了MySQL在某些场景下面临的挑战及其原因,并指出这些问题不能完全归咎于MySQL本身。高并发读写压力、数据量增长以及复杂查询和事务处理都可能导致性能瓶颈。然而,应用程序设计不合理、系统架构不佳以及其他数据库选择和优化策略不足也是重要因素。综合考虑这些方面才能有效解决性能问题,而MySQL通过不断改进和优化,仍然是许多应用场景中的可靠选择。
275 9
|
10月前
|
关系型数据库 MySQL 网络安全
如何排查和解决PHP连接数据库MYSQL失败写锁的问题
通过本文的介绍,您可以系统地了解如何排查和解决PHP连接MySQL数据库失败及写锁问题。通过检查配置、确保服务启动、调整防火墙设置和用户权限,以及识别和解决长时间运行的事务和死锁问题,可以有效地保障应用的稳定运行。
395 25
|
9月前
|
数据库连接 PHP 数据库
【YashanDB知识库】PHP使用ODBC使用数据库绑定参数功能异常
【YashanDB知识库】PHP使用ODBC使用数据库绑定参数功能异常
|
9月前
|
PHP 数据库
【YashanDB知识库】PHP使用OCI接口使用数据库绑定参数功能异常
【YashanDB知识库】PHP使用OCI接口使用数据库绑定参数功能异常
|
NoSQL 关系型数据库 PHP
php连接数据库
要使用PHP连接PolarDB或MongoDB数据库,需先准备连接信息,并编写相应代码。对于PolarDB,需设置主机地址、端口、数据库名及凭据,使用`pg_connect`函数建立连接;而对于MongoDB副本集,需安装MongoDB PHP驱动,通过`MongoDB\Client`连接指定的副本集实例。请确保替换示例代码中的占位符为实际值,并正确配置副本集名称和主机信息。更多详细信息与示例代码,请参考相关链接。
286 74
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
319 1
|
SQL 关系型数据库 MySQL
php学习笔记-连接操作mysq数据库(基础)-day08
本文介绍了PHP中连接操作MySQL数据库的常用函数,包括连接服务器、设置字符集、关闭连接、选择数据库、结果集释放、获取影响行数以及遍历结果集等操作。通过书籍查询的实例演示了如何使用这些函数进行数据库操作,并提供了一个PHP操纵MySQL数据库的模板。
php学习笔记-连接操作mysq数据库(基础)-day08
|
SQL 关系型数据库 数据库连接
php连接数据库之PDO,PDO的简单使用和预定义占位符的使用以及PDOStatement对象的使用,占位符的不同形式,bindValue和bindParam绑定预定义占位符参数的区别
本文介绍了PHP中PDO(PHP Data Objects)扩展的基本概念和使用方法。内容包括PDO类和PDOStatement类的介绍,PDO的简单使用,预定义占位符的使用方法,以及PDOStatement对象的使用。文章还讨论了绑定预定义占位符参数的不同形式,即bindValue和bindParam的区别。通过具体示例,展示了如何使用PDO进行数据库连接、数据查询、数据插入等操作。
php连接数据库之PDO,PDO的简单使用和预定义占位符的使用以及PDOStatement对象的使用,占位符的不同形式,bindValue和bindParam绑定预定义占位符参数的区别
|
SQL 关系型数据库 MySQL
PHP与数据库交互的艺术:深入探讨PDO扩展
【8月更文挑战第28天】在数字信息时代的海洋里,PHP作为一艘灵活的帆船,承载着无数网站和应用的梦想。而PDO扩展,则是这艘帆船上不可或缺的导航仪,指引着数据安全与效率的航向。本文将带你领略PHP与数据库交互的艺术,深入浅出地探索PDO的世界,从连接数据库到执行复杂的查询,每一步都清晰可见。我们将一起航行在这段奇妙的旅程上,解锁数据的奥秘,体验编程的乐趣。
228 1