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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
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(‘字段名’,‘表达式’,‘查询条件’);

image.png

$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();

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1天前
|
存储 JSON JavaScript
数据库操作对象 db,用于与浏览器的 localStorage 交互
数据库操作对象 db,用于与浏览器的 localStorage 交互
8 0
|
4天前
|
Java 数据库 Maven
自己本地模拟内存数据库增删改查
自己本地模拟内存数据库增删改查
4 0
|
5天前
|
编译器 API 数据库
技术好文共享:(xxxx)十一:SQLite3的db数据库解密(三)数据库在线备份
技术好文共享:(xxxx)十一:SQLite3的db数据库解密(三)数据库在线备份
|
5天前
|
存储 SQL PHP
PHP中的PDO与数据库交互
PHP的PDO扩展提供了一种方式来统一访问多种数据库
|
5天前
|
SQL 关系型数据库 MySQL
php mysqli操作数据库
php mysqli操作数据库
9 0
|
6天前
|
SQL 缓存 PHP
PHP 与数据库优化:提升Web应用性能的关键
在Web开发中,PHP作为一种流行的服务器端脚本语言,与数据库密切相关。本文探讨了如何通过PHP与数据库优化来提升Web应用的性能和响应速度。从数据库查询优化、索引的设计到PHP代码编写的最佳实践,我们将深入探讨每个方面如何影响应用的效率和用户体验。
|
8天前
|
关系型数据库 Java MySQL
Java关于Mysql数据库的事物处理类
Java关于Mysql数据库的事物处理类
|
13天前
|
SQL 监控 安全
代码审计-PHP原生开发篇&SQL注入&数据库监控&正则搜索&文件定位&静态分析
代码审计-PHP原生开发篇&SQL注入&数据库监控&正则搜索&文件定位&静态分析
|
13天前
|
存储 安全 关系型数据库
安全开发-PHP应用&留言板功能&超全局变量&数据库操作&第三方插件引用&后台模块&Session&Cookie&Token&身份验证&唯一性
安全开发-PHP应用&留言板功能&超全局变量&数据库操作&第三方插件引用&后台模块&Session&Cookie&Token&身份验证&唯一性
|
21天前
|
运维 JavaScript Serverless
Serverless 应用引擎产品使用合集之php工程已经部署,可以正常访问数据库,静态资源样式无法正常加载,要怎么配置
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
Serverless 应用引擎产品使用合集之php工程已经部署,可以正常访问数据库,静态资源样式无法正常加载,要怎么配置