Thinkphp5中怎么操作数据库,进行增删改查?下面本篇文章就来带大家详细了解一下Thinkphp5中增删改查数据库的方法,希望对大家有所帮助!
Thinkphp5中怎么操作数据库,进行增删改查?下面本篇文章就来带大家详细了解一下Thinkphp5中增删改查数据库的方法,希望对大家有所帮助!
【相关教程推荐:thinkphp框架】 一、创建model的文件夹在application文件夹下的二级对象目录中新建名为model的文件夹,该文件夹与对应的controller和view目录同级,如下图: 如果有多个模块(比如前台index,后台admin),操作的数据库都差不多,那么可以把model模型放到common公共模块里,如下: 二、创建model模型类1、在model目录下创建model对象文件,一般model的名字和表名是对应的,例如: 表名 pre_user ---------------> 模型名 User.php 表名 pre_user_info ---------------> 模型名 UserInfo.php 2、定义model模型 <?php namespace app\index\model; use think\Model; use think\Db; class User extends Model{ /** * 定义变量 * 1.变量名称应与数据表中的字段名相同 * 2.此处可根据需求省略,因为如果没有,thinkphp会自动在数据表中寻找的对应字段名 */ public $username; public $password; } ?> 3、如果数据模型定义名和表名不一致,那么就需要额外定义和声明,如下: <?php namespace app\index\model; use think\Model; use think\Db; class User extends Model { protected $table = "admin_user";//指定数据表名 protected $pk = 'id'; //指定主键的字段 } ?> 三、调用model模型的方法//导入定义的数据模型类 use \app\index\model\User; //方法一: $res = User::get(1); //方法二: $user = new User; $res = $user::get(1); //方法三: use think\Loader; $user = Loader::model("User"); $res = $user::get(1); //方法四: $user = model("User"); $res = $user::get(1); 四、查询操作get 获取一条记录 $res = User::get(1); all 获取多条记录 1、不传参 $result = User::all(); //查询出所有记录 2、参数为n,n为正整数 $result = User::all(1); //查询出id为1的记录 3、参数为'n1, n2, n3...' $result = User::all('7, 8, 9, 10'); //查询出id为7、8、9、10的4条记录 4、参数为[n1, n2, n3...] $result = User::all([7, 8, 9, 10]); //查询出id为7、8、9、10的4条记录 find 查询某一条 $res = User::where('id','1')->field('name')->find();
select 多条查询 $res = User::where('id','1')->field('name')->limit(2)->order('id DESC')->select(); value 按字段查询一条 $res = User::where('id','1')->value('name'); 将结果转换成数组 $res = $res->toArray(); 查询数目 //查询总条数 $res = User::count(); //按条件统计条数 $res = User::where('id','>',3)->count(); whereTime() 时间条件查询1、获取今天的信息 db('table')->whereTime('c_time', 'today')->select(); //也可以简化为下面方式 db('table')->whereTime('c_time', 'd')->select(); 2、获取昨天的信息 db('table')->whereTime('c_time', 'yesterday')->select(); 3、获取本周的信息 db('table')->whereTime('c_time', 'week')->select(); //也可以简化为下面方式 db('table')->whereTime('c_time', 'w')->select(); 4、获取本月的信息 db('table')->whereTime('c_time', 'month')->select(); //也可以简化为下面方式 db('table')->whereTime('c_time', 'm')->select(); 5、获取上月的信息 db('table')->whereTime('c_time','last month')->select(); 6、获取今年的信息 db('table')->whereTime('c_time', 'year')->select(); //也可以简化为下面方式 db('table')->whereTime('c_time', 'y')->select(); 7、获取去年的信息 db('table')->whereTime('c_time','last year')->select(); 8、日期区间查询 //根据时间戳查询今天到后天 db('table')->whereTime('time', 'between', [strtotime(date('Y-m-d')), strtotime(date('Y-m-d', strtotime('+2 day')))])->select(); 根据日期查询今天到后天 db('table')->whereTime('time', 'between', ['2020-3-28', '2020-3-30'])->select(); 五、添加操作1、使用create()方法添加 $res = User::create([ 'name' => '安阳', 'age' => 23, 'sex' => 1, 'password' => '123456' ]); 2、添加数据,并返回添加的主键 $uid=UserModel::create([ 'name' => '安阳', 'age' => 23, 'sex' => 1, 'password' => '123456' ])->id; 也可以使用DB类的insertGetId方法,如下: $uid = User::insertGetId([ 'name' => '安阳', 'age' => 23, 'sex' => 1, 'password' => '123456' ]); 3、实例化方式添加 $user = new User; $user->name = '安阳'; $user->age = 23; $user->save(); 4、实例化方式过滤插入字段,返回插入行数 $user = new User; $data = [ 'name' => '安阳', 'age' => 23, 'email' => '123456@qq.com' ]; //只有name和age字段会写入 $res = $user->allowField(['name', 'age'])->save($data); 5、模型使用allowField()过滤非数据表字段的数据 //定义模型对象,并传入post数据 $user = new User($_POST); //过滤post数组中的非数据表字段数据 $user->allowField(true)->save(); 6、模型使用allowField()指定某些字段写入 $user = new User; // post数组中只有name和email字段会写入 $user->allowField(['name','email'])->save($_POST, ['id' => 1]); 7、批量添加使用saveAll() user = new User; $list = [ ['name'=>'安阳','email'=>'thinkphp@qq.com'], ['name'=>'小柒','email'=>'12345678@qq.com'] ]; $user->saveAll($list); 也可以使用DB类的insertAll()方法,返回添加成功的条数 $res = User::insertAll([ 'name' => '安阳', 'age' => 23, 'sex' => 1, 'password' => '123456' ]);
6、saveAll添加多条数据,返回对象列表 $user = new User; $data = [ [ 'name' => '安阳', 'age' => 20, 'email' => '123456@qq.com' ], [ 'name' => '小柒', 'age' => 25, 'email' => 'ap555@qq.com' ] ]; $res = $user->allowField(['name', 'age'])->saveAll($data); 六、更新操作1、update 返回影响行数 $res = User::where(['id'=>1])->update(['name'=>'安阳']); 2、setField 单独更新某个字段 User::where('id',1)->setField('name','安阳'); 3、setInc //setInc('money',10)表示将money字段加上10 User::where(['id'=>1])->setInc('money', 10); 4、setDec //setDec('money',10)表示将money字段减去10 User::where(['id'=>1])->setDec('money', 10); 5、批量更新,要求数据中含有主键,返回更新对象列表 $user = new User; $res = $user->saveAll([ ['id'=>1, 'name' => '安阳'], ['id'=>2, 'name' => '小柒'] ]); 七、删除操作1、传入主键,返回影响行数 $res = User::destroy(1); 2、传入条件,返回影响行数 $res = User::destroy(['name'=>'安阳']); 3、条件删除 返回影响行数 $res = User::where(['id'=>1])->delete(); 八、事务1、自动控制事务处理 Db::transaction(function(){ Db::table('order')->where(['id'=>1])->delete(); Db::table('user')->where('id'=>1)->setInc('money',10); }); 2、手动控制事务 Db::startTrans();//启动事务 try { Order::where(['id'=>1])->delete(); User::where('id'=>1)->setInc('money',10); Db::commit();//提交事务 } catch (Exception $e) { Db::rollback(); //回滚 } 九、model模型的获取器
<?php namespace app\index\model; use think\Model; class User extends Model { //获取器:将性别的012修改为男、女、未知 返回 public function getSexAttr($val) { switch ($val) { case 1: return '男'; case 2: return '女'; default: return '未知'; } } //获取器:格式化时间戳后返回 public function getUpdateTimeAttr($val){ if(!empty($val)){ //如果是时间戳,就格式化 if(!strtotime($val)) { return date('Y-m-d H:i:s',$val); }else{ return $val; } }else{ return ''; } } } 补充说明:strtotime()将任何英文文本的日期时间描述解析为Unix 时间戳,成功则返回时间戳,否则返回 FALSE(在 PHP 5.1.0之前本函数在失败时返回 -1) 十、model模型的修改器<?php namespace app\index\model; use think\Model; class User extends Model { //修改器 public function setTimeAttr() { return time(); } /** 修改器:对密码字段加密之后存储 * $val 第一个参数是密码 * $data 第二个参数是添加的数据(可选) */ public function setPasswordAttr($val,$data){ if($val === '') { return $val; }else{ return md5($val.$data['email']); } } } 十一、model模型的自动完成
1、自动完成 <?php namespace app\index\model; use think\Model; class User extends Model { //添加和修改时,都会自动完成的字段 protected $auto = ['addtime']; public function setAddtimeAttr(){ return time(); } } 2、添加数据时,自动完成 <?php namespace app\index\model; use think\Model; class User extends Model { // 新增 自动完成 protected $insert = ['addtime']; public function setAddtimeAttr(){ return time(); } } 3、更新数据时,自动完成: <?php namespace app\index\model; use think\Model; class User extends Model { // 更新 自动完成 protected $update = ['addtime']; public function setAddtimeAttr(){ return time(); } } 十二、自动完成时间戳在数据库配置文件database.php中,有下列这项配置: //自动写入时间戳字段 'auto_timestamp' => false, //如果开启(设置为true),则会自动完成所有表的时间戳,但是不建议这样,只在需要的地方设置更安全。 例如对用户表的时间戳自动完成,就在User的model中设置: <?php namespace app\index\model; use think\Model; class User extends Model{ //开启自动完成时间戳功能 protected $autoWriteTimestamp = true; //开启后, //添加数据时,默认自动完成的字段是:create_time和update_time //修改数据时,默认自动完成的字段是:update_time //如果数据表里不是这两个字段,则会报错。需要进行如下修改: protected $createTime = 'addtime';//修改默认的添加时间字段 protected $updateTime = 'updtime';//修改默认的修改时间字段 protected $updateTime = false;//当不需要这个字段时设置为false }
十三、软删除
1、开启软删除 <?php namespace app\index\model; use think\Model; use traits\model\SoftDelete;//引入软删除的类 class Order extends Model{ //使用软删除 //删除时,默认更新的字段是delete_time use SoftDelete; //如果数据表里不是delete_time这个字段,则会报错。需要进行如下修改: protected $deleteTime = 'deltime'; } 2、 控制器里软删除,返回影响的行数 $res = Order::destroy(1); 执行删除后,就会更新delete_time字段,如果update_time字段也开启了自动完成,也会更新update_time字段。 3、如果开启了软删除,需要真正地删除数据,而不做软删除,用下面的方法 //destory()第二个参数传递true $res = Order::destroy(1,true); //delete()参数传递true $orderData = Order::get(1); $orderData ->delete(true); 4、查询已软删除的数据 $res = Order::withTrashed(true)->find(1); 5、查询仅包含已软删除的数据 $res = Order::onlyTrashed()->select(); 推荐学习:《PHP视频教程》 以上就是一文详解Thinkphp5中怎么增删改查数据库的详细内容,更多请关注模板之家(www.mb5.com.cn)其它相关文章! |