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 相关文章推荐
加速XP搜索功能堪比vista
Mar 22 PHP
PHP分页显示制作详细讲解
Nov 19 PHP
很好用的PHP数据库类
May 27 PHP
使用PHP获取网络文件的实现代码
Jan 01 PHP
PHP 解决utf-8和gb2312编码转换问题
Mar 18 PHP
php使用百度ping服务代码实例
Jun 19 PHP
如何让搜索引擎抓取AJAX内容解决方案
Aug 25 PHP
Yii入门教程之Yii安装及hello world
Nov 25 PHP
PHP里的单例类写法实例
Jun 25 PHP
php邮箱地址正则表达式验证
Nov 13 PHP
CodeIgniter配置之routes.php用法实例分析
Jan 19 PHP
详解如何在云服务器上部署Laravel
Jun 30 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
php实现用已经过去多长时间的方式显示时间
2015/06/05 PHP
JavaScript DOM 学习第五章 表单简介
2010/02/19 Javascript
拖动布局之保存布局页面cookies篇
2010/10/29 Javascript
JQuery实现倒计时按钮的实现代码
2012/03/23 Javascript
javascript正则表达式使用replace()替换手机号的方法
2015/01/19 Javascript
老司机带你解读jQuery插件开发流程
2016/05/16 Javascript
Javascript闭包与函数柯里化浅析
2016/06/22 Javascript
微信小程序 本地数据存储实例详解
2017/04/13 Javascript
JavaScript实现多重继承的方法分析
2018/01/09 Javascript
使用vue-route 的 beforeEach 实现导航守卫(路由跳转前验证登录)功能
2018/03/22 Javascript
js正则相关知识点专题
2018/05/10 Javascript
用react-redux实现react组件之间数据共享的方法
2018/06/08 Javascript
在Vue环境下利用worker运行interval计时器的步骤
2019/08/01 Javascript
[04:09]2018年度DOTA2社区贡献奖-完美盛典
2018/12/16 DOTA
[06:07]DOTA2-DPC中国联赛3月5日Recap集锦
2021/03/11 DOTA
Python3.2中的字符串函数学习总结
2015/04/23 Python
深入理解Python对Json的解析
2017/02/14 Python
Python实现调用另一个路径下py文件中的函数方法总结
2018/06/07 Python
Python运维自动化之nginx配置文件对比操作示例
2018/08/29 Python
django小技巧之html模板中调用对象属性或对象的方法
2018/11/30 Python
python使用response.read()接收json数据的实例
2018/12/19 Python
Python *args和**kwargs用法实例解析
2020/03/02 Python
Python telnet登陆功能实现代码
2020/04/16 Python
浅析数据存储的三种方式 cookie sessionstorage localstorage 的异同
2020/06/04 HTML / CSS
豪华复古化妆:Besame Cosmetics
2019/09/06 全球购物
Shopbop中文官网:美国亚马逊旗下时尚购物网站
2020/12/15 全球购物
某公司面试题
2012/03/05 面试题
心理健康日活动总结
2014/05/08 职场文书
幽默自我介绍演讲稿
2014/08/21 职场文书
2014大学辅导员工作总结
2014/12/02 职场文书
道德模范事迹材料
2014/12/20 职场文书
60条职场经典语录,总有一条能触动你的心
2019/08/21 职场文书
开发一个封装iframe的vue组件
2021/03/29 Vue.js
Springboot集成阿里云OSS上传文件系统教程
2021/06/28 Java/Android
十大必看国产动漫排名,魁拔上线,第二曾在日本播出
2022/03/18 国漫
彻底弄懂Python中的回调函数(callback)
2022/06/25 Python