如果有兴趣了解更多相关内容,欢迎来我的个人网站看看:eyes++的个人空间
一:定义
模型定义
模型会自动对应数据表,模型类的命名规则是除去表前缀的数据表名称,采用驼峰法命名,并且首字母大写。
模型自动对应的数据表名称都是遵循小写+下划线规范,如果你的表名有大写的情况,必须通过设置模型的table属性。
| 模型名 | 约定对应数据表(假设数据库的前缀定义是 think_) |
|---|---|
| User | think_user |
| UserType | think_user_type |

模型设置
模型的默认主键为id,如果你没有使用id作为主键名,需要在模型中设置属性,常用的模型设置属性包括(以下属性都不是必须设置):
| 属性 | 描述 |
|---|---|
| name | 模型名(相当于不带数据表前后缀的表名,默认为当前模型类名) |
| table | 数据表名(默认自动获取) |
| suffix | 数据表后缀(默认为空) |
| pk | 主键名(默认为id) |
| connection | 数据库连接(默认读取数据库配置) |
| query | 模型使用的查询类名称 |
| field | 模型允许写入的字段列表(数组) |
| schema | 模型对应数据表字段及类型 |
| type | 模型需要自动转换的字段及类型 |
| strict | 是否严格区分字段大小写(默认为true) |
| disuse | 数据表废弃字段(数组) |
设置方式如下:
<?php
namespace app\model;
use think\Model;
class Employees extends Model
{
// 设置模型名(相当于不带数据表前后缀的表名,默认为当前模型类名)
protected $name = 'Employees';
// 设置对应的表名
protected $table = 'employees';
// 设置主键(默认为id)
protected $pk = 'employee_id';
// 严格区分字段大小写
protected $strict = true;
}
模型初始化
init必须是静态方法,并且只在第一次实例化的时候执行,并且只会执行一次
protected static function init()
{
//TODO:初始化内容
}
模型操作
在模型中除了可以调用数据库类的方法之外(换句话说,数据库的所有查询构造器方法模型中都可以支持),可以定义自己的方法,所以也可以把模型看成是数据库的增强版。模型的操作方法无需和数据库查询一样调用必须首先调用table或者name方法,因为模型会按照规则自动匹配对应的数据表,例如:
Db::name('user')->where('id','>',10)->select();
改成模型操作的话就变成:
User::where('id','>',10)->select();
虽然看起来是相同的查询条件,但一个最明显的区别是查询结果的类型不同。第一种方式的查询结果是一个(二维)数组,而第二种方式的查询结果是包含了模型(集合)的数据集。不过,在大多数情况下,这二种返回类型的使用方式并无明显区别。
模型操作和数据库操作的另外一个显著区别是模型支持包括获取器、修改器、自动时间写入在内的一系列自动化操作和事件,简化了数据的存取操作,自动帮你处理了一些原本需要手动处理的操作。
动态切换后缀
新版模型增加了一个数据表后缀属性,可以用于多语言或者数据分表的模型查询,省去为多个相同结构的表定义多个模型的麻烦(默认的数据表后缀可以在模型类里面直接定义suffix属性)。
模型提供了动态切换方法suffix和setSuffix
// suffix方法用于静态查询
$blog = Blog::suffix('_en')->find();
$blog->name = 'test';
$blog->save();
// setSuffix用于动态设置
$blog = new Blog($data);
$blog->setSuffix('_en')->save();
二:模型字段
- 模型的数据字段和表字段是对应关系,默认会自动获取,包括字段的类型
- 自动获取会导致增加一次查询,如果在模型中配置字段信息,会减少内存开销
- 可以在模型设置$schema 字段,明确定义字段信息,字段需要对应表写完整;

- 字段类型的定义可以使用PHP类型或者数据库的字段类型都可以,字段类型定义的作用主要用于查询的参数自动绑定类型。
- 时间字段尽量采用实际的数据库类型定义,便于时间查询的字段自动识别。如果是json类型直接定义为json即可
- schema属性一旦定义,就必须定义完整的数据表字段类型。如果你只希望对某个字段定义需要自动转换的类型,可以使用type属性
<?php
namespace app\model;
use think\Model;
class User extends Model
{
// 设置字段自动转换类型
protected $type = [
'score' => 'float',
];
}
三:新增
模型数据的新增和数据库的新增数据有所区别,数据库的新增只是单纯的写入给定的数据,而模型的数据写入会包含修改器、自动完成以及模型事件等环节。
通过数组添加数据
示例是批量新增,所以$data是二维数组,增加单个数据只要换成一维数组就行了,另外,不要在同一个实例里面多次新增数据,如果确实需要多次新增,可以使用后面的静态方法处理。
<?php
namespace app\controller;

本文详细介绍了ThinkPHP框架中模型的使用,包括模型的定义、设置、初始化,以及数据的新增、更新、删除和查询操作。模型提供了自动化处理,如修改器、自动完成和事件,简化了数据库交互。强调了最佳实践,如使用create方法新增数据,先查询后更新以利用模型事件,以及根据需求选择合适的删除方法。同时,模型查询支持单个和多个数据获取,确保了灵活性和效率。
最低0.47元/天 解锁文章
5598





