【Thinkphp教程】模型定义

模型类一般位于项目的Lib/Model 目录下面,当我们创建一个UserModel类的时候,其实已经遵循了系统的约定。模型类的命名规则是除去表前缀的数据表名称,采用驼峰法命名,并且首字母大写,然后加上模型类的后缀定义Model,例如:
模型名(类名) 约定对应数据表(假设数据库的前缀定义是 think_)
UserModel think_user
UserTypeModel think_user_type
如果你的规则和上面的系统约定不符合,那么需要设置Model类的数据表名称属性。
在ThinkPHP的模型里面,有几个关于数据表名称的属性定义:
属性 说明
tableName 不包含表前缀的数据表名称,一般情况下默认和模型名称相同,只有当你的表名和当前的模型类的名称不同的时候才需要定义。
trueTableName 包含前缀的数据表名称,也就是数据库中的实际表名,该名称无需设置,只有当上面的规则都不适用的情况或者特殊情况下才需要设置。
dbName 定义模型当前对应的数据库名称,只有当你当前的模型类对应的数据库名称和配置文件不同的时候才需要定义。
下面举个例子来加深理解,例如,在数据库里面有一个think_categories表,而我们定义的模型类名称是CategoryModel,按照系统的约定,这个模型的名称是Category,对应的数据表名称应该是think_category(全部小写),但是现在的数据表名称是think_categories,因此我们就需要设置tableName属性来改变默认的规则(假设我们已经在配置文件里面定义了DB_PREFIX 为 think_)。
  1. protected $tableName = 'categories'; 

注意这个属性的定义不需要加表的前缀think_
而对于另外一种特殊情况,数据库中有一个表(top_depts)的前缀和其它表前缀不同,不是think_ 而是 top_,这个时候我们就需要定义 trueTableName 属性了
  1. protected $trueTableName = 'top_depts'; 

注意trueTableName需要完整的表名定义
除了数据表的定义外,还可以对数据库进行定义,例如:
  1. protected $dbName = 'top';

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ThinkPHP6 的模型运行机制主要是基于 ORM(对象关系映射)思想实现的,它将数据库中的数据表映射为一个个的模型,通过模型的方法来操作数据库中的数据,避免了直接操作数据库的复杂性,提高了代码的可维护性和可读性。 具体来说,ThinkPHP6 的模型运行机制包括以下几个方面: 1. 数据库连接:在模型中,通过继承 \think\Model 来实现数据库连接,可以在模型中通过 $this->db() 方法来获取当前模型对应的数据库连接实例。 2. 数据表映射:在模型中,通过定义 $table 属性来指定当前模型对应的数据表名称,也可以通过 $pk 属性来指定当前模型对应的数据表主键字段名称。 3. 查询构建器:在模型中,通过 $this->db() 方法返回的数据表查询构建器对象来实现对数据表的各种操作,如查询、更新、删除等。 4. 数据关联:在模型中,可以通过定义关联方法来实现不同数据表之间的关联,如一对一关联、一对多关联、多对多关联等。 5. 事件机制:在模型中,可以通过定义事件方法来实现对模型操作的监听,如 beforeInsert、afterInsert、beforeUpdate、afterUpdate、beforeDelete、afterDelete 等事件。 总之,ThinkPHP6 的模型运行机制非常灵活,可以通过模型来实现对数据表的各种操作,并且支持数据关联和事件机制,方便开发者进行快速开发。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值