Thinkphp5 使用 model 模型操作数据库
$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(
); //查询出所有记录?
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;
评论