您现在的位置是:首页 > 技术教程 正文

ThinkPHP8 使用Db类处理数据库CURD

admin 阅读: 2024-03-18
后台-插件-广告管理-内容页头部广告(手机)

ThinkPHP8 使用Db类处理数据库CURD

    • 查询
    • 增加
    • 更新
    • 删除

查询

(1)查询所有数据:如果开启表前缀可以使用name方法否则使用table方法

$user = Db::name('user')->select(); return json($user);
  • 1
  • 2

(2)查询id为1的一条数据使用find直接查询

$user = Db::name('user')->find(1); return json($user);
  • 1
  • 2

(3)查询id为1的一条数据通过where传入id查询

$user = Db::name('user')->where('id', 1)->find(); return json($user);
  • 1
  • 2

(4)打印一条不存在的数据会返回NULL 如果不想返回NULL可以使用findOrEmpty返回空数组

$user = Db::name('user')->where('id', 999)->findOrEmpty(); return json($user);
  • 1
  • 2

(5)打印一条不存在的数据会返回NULL 如果不想返回NULL可以使用findOrFail返回异常

$user = Db::name('user')->where('id', 999)->findOrFail(); return json($user);
  • 1
  • 2

(6)将输出转换为数组

$user = Db::name('user')->select()->toArray(); return json($user);
  • 1
  • 2

(7)中断测试使用halt()函数

$user = Db::name('user')->select()->toArray(); halt($user);
  • 1
  • 2

(8)使用select进行条件查询 获取年龄为14岁的所有数据

$user = Db::name('user')->where('age', 14)->select(); return json($user);
  • 1
  • 2

(9)使用value方法获取某一字段的值查询不到会返回NUll: 获取id为1的数据中name字段的值

$user = Db::name('user')->where('id', 1)->value('name'); return json($user);
  • 1
  • 2

(10)使用column方法获取指定列的多个值如果查询不到返回空数组[]: 返回整张表中name和age字段

$user = Db::name('user')->column('age', 'name'); return json($user);
  • 1
  • 2

(11)使用chunk方法批量处理数据:以下演示每次处理两条数据 || 通过下方例子中的echo 1;可以看到每两条数据就会输出一次1以此表示每次处理两条数据

Db::name('user')->chunk(2, function($users) { foreach($users as $user) { dump($user); } echo 1; });
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

(12)使用cursor游标处理内存开销:每次处理一条数据 echo 1可以看出处理一条数据打印一次1

$users = Db::name('user')->cursor(); foreach($users as $user) { dump($user); echo 1; }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

增加

(1)单条新增insert方法

$arr = [ 'name' => '白鹏', 'age' => 25, 'email' => 'baipeng@qq.com', 'status' => 1, 'details' => '我是傻逼' ]; $user = Db::name('user')->insert($arr); return json($user);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

(2)关闭严格检查strict方法: 输入了错误的字段也可也i执行成功 不过数据表中会存在空数据

$arr = [ 'name' => '白鹏', 'age' => 25, 'gender' => '男', 'abc' => 1, 'details' => '我是傻逼' ]; $user = Db::name('user')->strict(false)->insert($arr); return json($user);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

(3)使用insertGetId方法: 返回插入行的ID

$data = [ 'name' => '王烨', 'age' => 20, 'details' => '我是王烨', 'gender' => '男' ]; $user = Db::name('user')->insertGetId($data); return $user;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

(4)使用replace方法: 如果插入的数据(必须有ID)原本就存在数据库中 那么insert将会变为修改 只更新与数据库中信息不同的字段

$data = [ ‘id' => 1, 'name' => '王烨', 'age' => 20, 'aaa' => '我是王烨', 'gender' => '男' ]; $user = Db::name('user')->replace()->insert($data); return $user;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

(5)使用insertAll方法: 插入多条数据 数据解构必须一致

一、原始

$data = [ [ 'name' => '李嘉诚', 'age' => 20, 'gender' => '男', 'details' => '我是李嘉诚' ], [ 'name' => '王乾', 'age' => 20, 'gender' => '男', 'details' => '我是王乾' ], [ 'name' => '许欢', 'age' => 20, 'gender' => '女', 'details' => '我是许欢' ] ]; $user = Db::name('user')->insertAll($data); return $user;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23

二、insertAll方法也可以使用replace方法 并且如果插入数量过大的话 可以使用limit方法来限制每次插入的条数

下方代码演示的为 更新多批数据 按照每次更新100条来更新

$user = Db::name('user')->limit(100)->insertAll([数据数组]);
  • 1

更新

(1)原始update更新数据

$data = [ 'name' => '王乾', 'age' => 13 ]; return Db::name('user')->where('id', 100)->update($data);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

(2)如果需要修改的数组中已经写出了id 可以省略where条件

$data = [ 'id' => 100, 'name' => '王乾', 'age' => 13 ]; return Db::name('user')->update($data);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

(3)使用exp方法 可以在修改字段时执行SQL函数

一、exp 方法用于构建 SQL 表达式的一部分,而 Db::raw 用于插入完整的原始 SQL 片段

二、两者是不同的!!! Db::raw在后面讲解

三、以下演示修改数据时候 使用exp方法 将details(个人简介)字段中的英文改为UPPER(大写)

$data = [ 'id' => 100, 'name' => '我不是王乾', ]; return Db::name('user')->exp('details', "UPPER(details)")->update($data);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

(4)使用inc方法 可以在更新字段时候为字段设置自增条件

一、以下演示age(年龄)字段 语句执行后age自增1

$data = [ 'id' => 100, 'name' => '我不是王乾', ]; return Db::name('user')->inc('age')->update($data);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

二、为inc方法添加第二个参数 也就是步长 代表每次自增多少 以下为每次自增 2

$data = [ 'id' => 100, 'name' => '我不是王乾', ]; return Db::name('user')->inc('age', 2)->update($data);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

(4)使用dec方法 可以在更新字段时候为字段设置自减条件

一、原理与inc自增方法一致 以下仅演示默认使用方法

$data = [ 'id' => 100, 'name' => '我不是王乾', ]; return Db::name('user')->dec('age')->update($data);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

(5)使用Db::raw 用于插入完整的原始 SQL 片段 用以设置每个字段的特殊需求

一、以下语句执行后 details(个人介绍)字段中的英文字母会UPPER(大写) age(年龄)字段会减少2

$data = [ 'details' => Db::raw("UPPER(details)"), 'age' => Db::raw("age - 2") ]; return Db::name('user')->where('id', 4)->update($data);
  • 1
  • 2
  • 3
  • 4
  • 5

(6)使用save方法 如果条件语句包含 主键 的话那就是修改这条数据 如果不包含 主键 的话那就是新增这条数据

一、以下语句展示不包含主键id进行新增一条数据

$data = [ 'name' => '张子豪', 'age' => 20, 'details' => '我是张子豪', 'gender' => '男' ]; return Db::name('user')->save($data);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

二、以下展示包含主键id进行修改一条数据

$data = [ 'id' => 102, 'name' => '张子豪', 'age' => 15, 'details' => '我不是张子豪', 'gender' => '男' ]; return Db::name('user')->save($data);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

删除

一、实际使用中 软删除使用的更多 真实的删除使用的较少 不建议直接删除数据库中的数据!!!

(1)原生DELETE方法 删除一条数据

一、使用where传入主键id where方法不仅可以传入id 还可以传入各种字段来删除都可以

return Db::name('user')->where('id', 102)->delete();
  • 1

二、如果没有使用where方法传入id 也可以直接使用delete方法传入id来删除数据

return Db::name('user')->delete(102);
  • 1

(2)批量删除数据 依旧使用DELETE方法 不过参数传入一个数组即可

一、以下展示删除第一条至第六条 六条数据批量删除

return Db::name('user')->delete([1, 2, 3, 4, 5, 6]);
  • 1

9、使用表达式规则查询数据 -> 表达式查询

一、查询表达式语法格式: where('字段名称', '查询表达式', '查询条件');

二、一般都用两种方法 默认的where方法以及 其它如whereLike的这种快捷方式, 推荐使用快捷方式 快捷方式绕过了SQL语句组装流程 速度更快!!!

(1)查询id大于50的全部数据

$user = Db::name('user')->where('id', '>', 50)->select(); return json($user);
  • 1
  • 2
  • 3

(2)模糊查询 查询name为 王% 也就是姓王的

一、使用where方法

$user = Db::name('user')->where('name', 'like', '王%')->select(); return json($user);
  • 1
  • 2
  • 3

二、使用whereLike方法 只需要传入两个参数 第一个是要查询的字段 第二个是设置规则

$user = Db::name('user')->whereLike('name', '王%')->select(); return json($user);
  • 1
  • 2
  • 3

(3)查询id为1 3 5的三条数据

一、使用where方法

$user = Db::name('user')->where('id', 'in', [1, 3, 4])->select(); return json($user);
  • 1
  • 2
  • 3

二、使用whereIn方法

$user = Db::name('user')->whereIn('id', [1, 3, 5])->select(); return json($user);
  • 1
  • 2
  • 3

(4)区间查询 between 查询id 从2到5(包含2和5) 的四条数据

一、使用where方法

$user = Db::name('user')->where('id', 'between', [2, 5])->select(); return json($user);
  • 1
  • 2
  • 3

二、使用whereBetween方法

$user = Db::name('user')->whereBetween('id', [2, 5])->select(); return json($user);
  • 1
  • 2
  • 3

(5)区间查询 notbetween 查询id 除了2到5 意外的数据

一、使用where方法

$user = Db::name('user')->where('id', 'notbetween', [2, 5])->select(); return json($user);
  • 1
  • 2
  • 3

二、使用whereNotBetween方法

$user = Db::name('user')->whereNotBetween('id', [2, 5])->select(); return json($user);
  • 1
  • 2
  • 3
标签:
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

在线投稿:投稿 站长QQ:1888636

后台-插件-广告管理-内容页尾部广告(手机)
关注我们

扫一扫关注我们,了解最新精彩内容

搜索
排行榜