写点什么

Thinkphp5 使用 model 模型操作数据库

用户头像
Android架构
关注
发布于: 35 分钟前

$user = new User;


user::get(1);


//方法三:


use think\Loader;


$user = Loader::model("User");


user::get(1);


//方法四:


$user = model("User");


user::get(1);

四、查询操作

get 获取一条记录


$res = User::get(1);


all 获取多条记录


1、不传参


$result = User::all(


《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》
浏览器打开:qq.cn.hn/FTe 免费领取
复制代码


); //查询出所有记录?


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


?不等于



->where('id','neq',1)


select 多条查询


$res = User::where('id','1')->field('name')->limit(2)->order('id DESC')->select();


value 按字段查询一条


$res = User::where('id','1')->value('name');


将结果转换成数组


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 字段会写入


user->allowField(['name', 'age'])->save($data);


5、模型使用 allowField()过滤非数据表字段的数据


//定义模型对象,并传入 post 数据


_POST);


//过滤 post 数组中的非数据表字段数据


$user->allowField(true)->save();


6、模型使用 allowField()指定某些字段写入


$user = new User;


// post 数组中只有 name 和 email 字段会写入


_POST, ['id' => 1]);


7、批量添加使用 saveAll()


user = new User;


$list = [


['name'=>'安阳','email'=>'thinkphp@qq.com'],


['name'=>'小柒','email'=>'12345678@qq.com']


];


list);


也可以使用 DB 类的 insertAll()方法,返回添加成功的条数?


$res = User::insertAll([


'name' => '安阳',


'age' => 23,


'sex' => 1,


'password' => '123456'


]);


补充,过滤字段的其他方法:



1、在 DB 操作中,可以使用 strict 关闭字段严格检查



Db::name(‘user’)->strict(false)->insert($data);



2、使用 php 的 unset() 方法销毁变量



unset($data[‘file’]);


6、saveAll 添加多条数据,返回对象列表


$user = new User;


$data = [


[


'name' => '安阳',


'age' => 20,


'email' => '123456@qq.com'


],


[


'name' => '小柒',


'age' => 25,


'email' => 'ap555@qq.com'


]


];


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;


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 模型的获取器

读取器的命名规范是:->get + 属性名的驼峰命名 + Attr


<?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(data){


if($val === '') {


return $val;


}else{


return md5(data['email']);


}


}


}

十一、model 模型的自动完成

auto ? ? ? 新增及更新的时候,自动完成的属性数组


insert? ? ?仅新增的时候,自动完成的属性数组


update? ?仅更新的时候,自动完成的属性数组


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;

用户头像

Android架构

关注

还未添加个人签名 2021.10.31 加入

还未添加个人简介

评论

发布
暂无评论
Thinkphp5使用model模型操作数据库