tp5.1 框架数据库常见操作详解【添加、删除、更新、查询】


Posted in PHP onMay 26, 2020

本文实例讲述了tp5.1 框架数据库常见操作。分享给大家供大家参考,具体如下:

tp5.1--数据库添加操作

使用 Db 类的 insert方法向数据库提交数据

$data = ['foo' => 'bar', 'bar' => 'foo'];
Db::name('user')->insert($data);

insert方法添加数据成功返回添加成功的条数,通常情况返回 1

或者使用data方法配合insert使用。

$data = ['foo' => 'bar', 'bar' => 'foo'];
Db::name('user')
  ->data($data)
  ->insert();

如果你的数据表里面没有foo或者bar字段,那么就会抛出异常。

如果不希望抛出异常,可以使用下面的方法:

$data = ['foo' => 'bar', 'bar' => 'foo'];
Db::name('user')->strict(false)->insert($data);

不存在的字段的值将会直接抛弃。

如果是mysql数据库,支持replace写入,例如:

$data = ['foo' => 'bar', 'bar' => 'foo'];
Db::name('user')->insert($data, true);

添加数据后如果需要返回新增数据的自增主键,可以使用insertGetId方法新增数据并返回主键值:

$userId = Db::name('user')->insertGetId($data);

insertGetId 方法添加数据成功返回添加数据的自

添加多条数据

添加多条数据直接向 Db 类的 insertAll 方法传入需要添加的数据即可

$data = [
  ['foo' => 'bar', 'bar' => 'foo'],
  ['foo' => 'bar1', 'bar' => 'foo1'],
  ['foo' => 'bar2', 'bar' => 'foo2']
];
Db::name('user')->insertAll($data);

insertAll 方法添加数据成功返回添加成功的条数

如果是mysql数据库,支持replace写入,例如:

$data = [
  ['foo' => 'bar', 'bar' => 'foo'],
  ['foo' => 'bar1', 'bar' => 'foo1'],
  ['foo' => 'bar2', 'bar' => 'foo2']
];
Db::name('user')->insertAll($data, true);

添加数据

添加一条数据

使用 Db 类的 insert 方法向数据库提交数据

$data = ['foo' => 'bar', 'bar' => 'foo'];
Db::name('user')->insert($data);

insert 方法添加数据成功返回添加成功的条数,通常情况返回 1

或者使用data方法配合insert使用。

$data = ['foo' => 'bar', 'bar' => 'foo'];
Db::name('user')
  ->data($data)
  ->insert();

如果你的数据表里面没有foo或者bar字段,那么就会抛出异常。

如果不希望抛出异常,可以使用下面的方法:

$data = ['foo' => 'bar', 'bar' => 'foo'];
Db::name('user')->strict(false)->insert($data);

不存在的字段的值将会直接抛弃。

如果是mysql数据库,支持replace写入,例如:

$data = ['foo' => 'bar', 'bar' => 'foo'];
Db::name('user')->insert($data, true);

添加数据后如果需要返回新增数据的自增主键,可以使用insertGetId方法新增数据并返回主键值:

$userId = Db::name('user')->insertGetId($data);

insertGetId 方法添加数据成功返回添加数据的自增主键

添加多条数据

添加多条数据直接向 Db 类的 insertAll 方法传入需要添加的数据即可

$data = [
  ['foo' => 'bar', 'bar' => 'foo'],
  ['foo' => 'bar1', 'bar' => 'foo1'],
  ['foo' => 'bar2', 'bar' => 'foo2']
];
Db::name('user')->insertAll($data);

insertAll 方法添加数据成功返回添加成功的条数

如果是mysql数据库,支持replace写入,例如:

$data = [
  ['foo' => 'bar', 'bar' => 'foo'],
  ['foo' => 'bar1', 'bar' => 'foo1'],
  ['foo' => 'bar2', 'bar' => 'foo2']
];
Db::name('user')->insertAll($data, true);

也可以使用data方法

$data = [
  ['foo' => 'bar', 'bar' => 'foo'],
  ['foo' => 'bar1', 'bar' => 'foo1'],
  ['foo' => 'bar2', 'bar' => 'foo2']
];
Db::name('user')->data($data)->insertAll();

确保要批量添加的数据字段是一致的

如果批量插入的数据比较多,可以指定分批插入,使用limit方法指定每次插入的数量限制。

$data = [
  ['foo' => 'bar', 'bar' => 'foo'],
  ['foo' => 'bar1', 'bar' => 'foo1'],
  ['foo' => 'bar2', 'bar' => 'foo2']
  ...
];
// 分批写入 每次最多100条数据
Db::name('user')->data($data)->limit(100)->insertAll();

tp5.1--数据库删除操作

删除数据

// 根据主键删除
Db::table('think_user')->delete(1);
Db::table('think_user')->delete([1,2,3]);
 
// 条件删除  
Db::table('think_user')->where('id',1)->delete();
Db::table('think_user')->where('id','<',10)->delete();

最终生成的SQL语句可能是:

DELETE FROM `think_user` WHERE `id` = 1 
DELETE FROM `think_user` WHERE `id` IN (1,2,3) 
DELETE FROM `think_user` WHERE `id` = 1 
DELETE FROM `think_user` WHERE `id` < 10

delete 方法返回影响数据的条数,没有删除返回 0

如果不带任何条件调用delete方法会提示错误,如果你确实需要删除所有数据,可以使用

// 无条件删除所有数据
Db::name('user')->delete(true);

最终生成的SQL语句是(删除了表的所有数据):

DELETE FROM `think_user`

一般情况下,业务数据不建议真实删除数据,系统提供了软删除机制(模型中使用软删除更为方便)。

// 软删除数据 使用delete_time字段标记删除
Db::name('user')
 ->where('id', 1)
 ->useSoftDelete('delete_time',time())
  ->delete();

实际生成的SQL语句可能如下(执行的是UPDATE操作):

UPDATE `think_user` SET `delete_time` = '1515745214' WHERE `id` = 1

useSoftDelete方法表示使用软删除,并且指定软删除字段为delete_time,写入数据为当前的时间戳。

tp5.1--数据库更新操作

更新数据

Db::name('user')
  ->where('id', 1)
  ->update(['name' => 'thinkphp']);

实际生成的SQL语句可能是:

UPDATE `think_user` SET `name`='thinkphp' WHERE `id` = 1

update 方法返回影响数据的条数,没修改任何数据返回 0

支持使用data方法传入要更新的数据

Db::name('user')
  ->where('id', 1)
  ->data(['name' => 'thinkphp'])
  ->update();

如果update方法和data方法同时传入更新数据,则会进行合并。

如果数据中包含主键,可以直接使用:

Db::name('user')
  ->update(['name' => 'thinkphp','id'=>1]);

实际生成的SQL语句和前面用法是一样的:

UPDATE `think_user` SET `name`='thinkphp' WHERE `id` = 1

如果要更新的数据需要使用SQL函数或者其它字段,可以使用下面的方式:

Db::name('user')
  ->where('id',1)
  ->inc('read_time')
  ->dec('score',3)
  ->exp('name','UPPER(name)')
  ->update();

实际生成的SQL语句:

UPDATE 
  `think_user` 
SET 
  `read_time` = `read_time` + 1 , 
  `score` = `score` - 3 , 
  `name` = UPPER(name) 
WHERE 
  `id` = 1

V5.1.7+版本以后,支持使用raw方法进行数据更新,适合在数组更新的情况。

Db::name('user')
  ->where('id', 1)
  ->update([
    'name' => Db::raw('UPPER(name)'),
    'score' => Db::raw('score-3'),
    'read_time' => Db::raw('read_time+1')
  ]);

更新字段值

Db::name('user')
  ->where('id',1)
  ->setField('name', 'thinkphp');

最终生成的SQL语句可能如下:

UPDATE `think_user` SET `name` = 'thinkphp' WHERE `id` = 1

setField 方法返回影响数据的条数,没修改任何数据字段返回 0

可以使用setInc/setDec方法自增或自减一个字段的值( 如不加第二个参数,默认步长为1)。

// score 字段加 1
Db::table('think_user')
  ->where('id', 1)
  ->setInc('score');
// score 字段加 5
Db::table('think_user')
  ->where('id', 1)
  ->setInc('score', 5);
// score 字段减 1
Db::table('think_user')
  ->where('id', 1)
  ->setDec('score');
// score 字段减 5
Db::table('think_user')
  ->where('id', 1)
  ->setDec('score', 5);

最终生成的SQL语句可能是:

UPDATE `think_user` SET `score` = `score` + 1 WHERE `id` = 1
UPDATE `think_user` SET `score` = `score` + 5 WHERE `id` = 1
UPDATE `think_user` SET `score` = `score` - 1 WHERE `id` = 1
UPDATE `think_user` SET `score` = `score` - 5 WHERE `id` = 1

setInc/setDec支持延时更新,如果需要延时更新则传入第三个参数,下例中延时10秒更新。

Db::name('user')->where('id', 1)->setInc('score', 1, 10);

setInc/setDec 方法返回影响数据的条数,如果使用了延迟更新的话,可能会返回true

tp5.1--数据库查询操作

selectOrFail();//在没有查找到数据后抛出异常

Db::table('think_user')->where('status',1)->selectOrFail();

findOrFail();//在没有查找到数据后抛出异常

Db::table('think_user')->where('id',1)->findOrFail();

findOrEmpty();//当查询不存在时,返回空数组

Db::table('think_user')->where('id',1)->findOrEmpty();

查询某个字段的值,结果不存在时,返回null

Db::table('think_user')->where('id',1)->value('name');

查询某一列的值

// 返回数组
Db::table('think_user')->where('status',1)->column('name');
// 指定id字段的值作为索引
Db::table('think_user')->where('status',1)->column('name','id');

返回完整数据,并且添加一个索引值,查询结果不存在,返回空数组

// 指定id字段的值作为索引 返回所有数据
Db::table('think_user')->where('status',1)->column('*','id');

返回某一条数据的一个字段值

Db::name('user')->where(['id' => 1])->value('name');

数据分批处理

全部用户表数据进行分批处理,每次处理 100 个用户记录:

Db::table('think_user')->chunk(100, function($users) {
  foreach ($users as $user) {
    //
  }
});
// 或者交给回调方法myUserIterator处理
Db::table('think_user')->chunk(100, 'myUserIterator');

通过从闭包函数中返回false来中止对后续数据集的处理:

Db::table('think_user')->chunk(100, function($users) {
  foreach ($users as $user) {
    // 处理结果集...
 if($user->status==0){
      return false;
    }
  }
});

支持在chunk方法之前调用其它的查询方法,例如:

Db::table('think_user')
->where('score','>',80)
->chunk(100, function($users) {
  foreach ($users as $user) {
    //
  }
});

chunk方法的处理默认是根据主键查询,支持指定字段,例如:

Db::table('think_user')->chunk(100, function($users) {
  // 处理结果集...
  return false;
},'create_time');

并且支持指定处理数据的顺序。

Db::table('think_user')->chunk(100, function($users) {
  // 处理结果集...
  return false;
},'create_time', 'desc');

chunk方法一般用于命令行操作批处理数据库的数据,不适合WEB访问处理大量数据,很容易导致超时。

大批量数据处理

如果需要处理大量的数据,可以使用新版提供的游标查询功能,该查询方式利用了PHP的生成器特性,可以大幅减少大量数据查询的内存占用问题。

$cursor = Db::table('user')->where('status', 1)->cursor();
foreach($cursor as $user){
 echo $user['name'];
}

cursor方法返回的是一个生成器对象,user变量是数据表的一条数据(数组)。

JSON类型数据查询(mysql)

// 查询JSON类型字段 (info字段为json类型)
Db::table('think_user')
 ->where('info->email','thinkphp@qq.com')
 ->find();

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

PHP 相关文章推荐
Windows下的PHP5.0安装配制详解
Sep 05 PHP
做一个有下拉功能的留言版
Oct 09 PHP
[原创]PHP中通过ADODB库实现调用Access数据库之修正版本
Dec 31 PHP
php正则取img标记中任意属性(正则替换去掉或改变图片img标记中的任意属性)
Aug 13 PHP
php页码形式分页函数支持静态化地址及ajax分页
Mar 28 PHP
Yii中render和renderPartial的区别
Sep 03 PHP
php实现格式化多行文本为Js可用格式
Apr 15 PHP
php结合正则获取字符串中数字
Jun 19 PHP
php获取当前页面完整URL地址
Dec 30 PHP
PHP使用pear实现mail发送功能 windows环境下配置pear
Apr 15 PHP
PHP精确到毫秒秒杀倒计时实例详解
Mar 14 PHP
PHP常量DIRECTORY_SEPARATOR原理及用法解析
Nov 10 PHP
Laravel 修改验证异常的响应格式实例代码详解
May 25 #PHP
tp5.1 框架查询表达式用法详解
May 25 #PHP
tp5.1 框架数据库高级查询技巧实例总结
May 25 #PHP
thinkphp5.1 框架导入/导出excel文件操作示例
May 25 #PHP
thinkphp5.1框架模板赋值与变量输出示例
May 25 #PHP
thinkphp5.1 框架钩子和行为用法实例分析
May 25 #PHP
php7 参数、整形及字符串处理机制修改实例分析
May 25 #PHP
You might like
总集篇&特番节目先行播出!《SAO Alicization War of Underworld》第2季度TV动画4月25日放送!
2020/03/06 日漫
Mysql中limit的用法方法详解与注意事项
2008/04/19 PHP
详解php中curl返回false的解决办法
2019/03/18 PHP
地址栏传递中文参数乱码在js里用escape转码
2013/08/28 Javascript
javascript函数声明和函数表达式区别分析
2014/12/02 Javascript
jQuery中html()方法用法实例
2014/12/25 Javascript
JavaScript中的依赖注入详解
2015/03/18 Javascript
jQuery EasyUi 验证功能实例解析
2017/01/06 Javascript
@ResponseBody 和 @RequestBody 注解的区别
2017/03/08 Javascript
自定义事件解决重复请求BUG的问题
2017/07/11 Javascript
Vue列表页渲染优化详解
2017/07/24 Javascript
基于Particles.js制作超炫粒子动态背景效果(仿知乎)
2017/09/13 Javascript
基于Vue实现可以拖拽的树形表格实例详解
2018/10/18 Javascript
在vue中使用echarts图表实例代码详解
2018/10/22 Javascript
小程序跨页面交互的作用与方法详解
2020/01/07 Javascript
小程序实现点击tab切换左右滑动
2020/11/16 Javascript
Python实现的一个找零钱的小程序代码分享
2014/08/25 Python
python正则表达式之作业计算器
2016/03/18 Python
python中文乱码不着急,先看懂字节和字符
2017/12/20 Python
python 将对象设置为可迭代的两种实现方法
2019/01/21 Python
解决python打不开文件(文件不存在)的问题
2019/02/18 Python
Django实现文件上传和下载功能
2019/10/06 Python
使用Python的networkx绘制精美网络图教程
2019/11/21 Python
使用python去除图片白色像素的实例
2019/12/12 Python
numpy的Fancy Indexing和array比较详解
2020/06/11 Python
python实现邮件循环自动发件功能
2020/09/11 Python
Sephora丝芙兰澳洲官方网站:国际知名化妆品购物
2016/10/27 全球购物
新闻专业个人求职信
2013/12/19 职场文书
高中历史教学反思
2014/02/08 职场文书
机关工会开展学习雷锋活动总结
2014/03/01 职场文书
应聘编辑自荐信范文
2014/03/12 职场文书
十一国庆节“向国旗敬礼”主题班会活动方案
2014/09/27 职场文书
2015年化妆品销售工作总结
2015/05/11 职场文书
python实现Nao机器人的单目测距
2021/09/04 Python
python实现对doc、txt、xls等文档的读写操作
2022/04/02 Python
悬疑名作《朋友游戏》动画无字ED宣传片 新角色公开
2022/04/13 日漫