美文网首页
tp中遇到的相关方法

tp中遇到的相关方法

作者: 左神话 | 来源:发表于2017-01-02 17:09 被阅读1005次

getDbFields
这个方法在tp手册的字段定义中
通常每个模型类是操作某个数据表,在大多数情况下,系统会自动获取当前数据表的字段信息。
系统会在模型首次实例化的时候自动获取数据表的字段信息(而且只需要一次,以后会永久缓存字段信息,除非设置不缓存或者删除),如果是调试模式则不会生成字段缓存文件,则表示每次都会重新获取数据表字段信息。
字段缓存保存在Runtime/Data/_fields/
目录下面,缓存机制是每个模型对应一个字段缓存文件(注意:并非每个数据表对应一个字段缓存文件),命名格式是:
数据库名.数据表前缀+模型名(小写).php

demo.think_user.php // User模型生成的字段缓存文件
demo.top_article.php // Article模型生成的字段缓存文件

字段缓存包括数据表的字段信息、主键字段和是否自动增长,如果开启字段类型验证的话还包括字段类型信息等等,无论是用M方法还是D方法,或者用原生的实例化模型类一般情况下只要是不开启调试模式都会生成字段缓存(字段缓存可以单独设置关闭)。
可以通过设置DB_FIELDS_CACHE
参数来关闭字段自动缓存,如果在开发的时候经常变动数据库的结构,而不希望进行数据表的字段缓存,可以在项目配置文件中增加如下配置:

// 关闭字段缓存
'DB_FIELDS_CACHE'=>false

注意:调试模式下面由于考虑到数据结构可能会经常变动,所以默认是关闭字段缓存的。
如果需要显式获取当前数据表的字段信息,可以使用模型类的getDbFields方法来获取当前数据对象的全部字段信息,例如:

$User = M('User');
$fields = $User->getDbFields();

如果你在部署模式下面修改了数据表的字段信息,可能需要清空Data/_fields目录下面的缓存文件,让系统重新获取更新的数据表字段信息,否则会发生新增的字段无法写入数据库的问题。

如果不希望依赖字段缓存或者想提高性能,也可以在模型类里面手动定义数据表字段的名称,可以避免IO加载的效率开销,例如:

namespace Home\Model;
use Think\Model;
class UserModel extends Model 
{ 
protected $fields = array('id', 'username', 'email', 'age');
 protected $pk = 'id';
//pk属性定义当前数据表的主键名,默认值就是id,因此如果是id的话可以无需定义
}

如果你的数据表使用了复合主键,可以这样定义:

namespace Home\Model;
use Think\Model;
class ScoreModel extends Model {
 protected $fields = array('user_id', 'lession_id','score'); 
protected $pk = array('user_id','lession_id');
}

除了可以设置数据表的字段之外,我们还可以定义字段的类型,用于某些验证环节。例如:

namespace Home\Model;
use Think\Model;
class UserModel extends Model {
  protected $fields = array('id', 'username', 'email', 'age', '_type'=>
array('id'=>'bigint','username'=>'varchar','email'=>'varchar','age'=>'int') );}

相关文章

  • tp中遇到的相关方法

    getDbFields这个方法在tp手册的字段定义中通常每个模型类是操作某个数据表,在大多数情况下,系统会自动获取...

  • ThinkPHP 模板输出

    TP模板中输出方法:

  • TP5中的getField()方法变化,tp5获取单个字段值

    tp5的getField()方法变了,具体如下: TP5中的getField():拆分为value和column了...

  • TP框架中的A方法

    通过A方法跨模块调用操作 A方法用于实例化其他模块(当于new关键字),模块被实例化之后,就可以以对象的方式调用模...

  • 求树的所有叶子结点

    工作中遇到一个需求,任意给一个结点id,求出其所有的叶子结点。 上面的方法在一个TP类中,所以调用方法就直接用$t...

  • 有关TP5中Query.php中废弃写法

    这是在TP5[https://www.php.cn/phpkj/thinkphp/]使用链式方法查询数据库时遇到的...

  • 早安群分享

    具体生活 理性相关(高度)一、运动1、 收益与tp关联,便于较大,便于教练指导 ,下重金投入运动2、方法,紧急跑步...

  • tp图像处理

    tp图像处理 [TOC] 表单: pic方法:

  • Mysql主从复制及配置实现以及坑坑坑

    今天搞Mysql主从复制,遇到了很多坑,在此记录相关操作。今天用tp5.1进行mysql 的主从复制,数据库配置如...

  • 2019-01-26 tp5.1

    1.静态方法和普通方法 静态方法是指不需要实例化属于类的方法,建议使用静态方法提高效率,tp5.1中静态方法的...

网友评论

      本文标题:tp中遇到的相关方法

      本文链接:https://www.haomeiwen.com/subject/vriwvttx.html