01
2023
08

thinkphp6模型:一:定义

模型定义

模型会自动对应数据表,模型类的命名规则是除去表前缀的数据表名称,采用驼峰法命名,并且首字母大写。
模型自动对应的数据表名称都是遵循小写+下划线规范,如果你的表名有大写的情况,必须通过设置模型的table属性。

模型名约定对应数据表(假设数据库的前缀定义是 think_
Userthink_user
UserTypethink_user_type

在这里插入图片描述在这里插入图片描述

模型设置

模型的默认主键为id,如果你没有使用id作为主键名,需要在模型中设置属性,常用的模型设置属性包括(以下属性都不是必须设置):

属性描述
name模型名(相当于不带数据表前后缀的表名,默认为当前模型类名)
table数据表名(默认自动获取)
suffix数据表后缀(默认为空)
pk主键名(默认为id
connection数据库连接(默认读取数据库配置)
query模型使用的查询类名称
field模型允许写入的字段列表(数组)
schema模型对应数据表字段及类型
type模型需要自动转换的字段及类型
strict是否严格区分字段大小写(默认为true)
disuse数据表废弃字段(数组)

设置方式如下:

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


« 上一篇下一篇 »

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。