模型查询数据库,当字段和模型属性重复那么数据调用问题?

浏览:776 发布日期:2016/12/09 分类:ThinkPHP5专区
TP5模型查询数据很多都是返回的是一个对象,而不是以前的数组了。然而测试发存在如下问题:

非模型类没有问题$list = model('DbName')->select();
foreach ($list as $k=>$v){
     dump($v->name); //输出数据库name字段值
}
如果是自身模型类出现问题$list = $this->select();
foreach ($list as $k=>$v){
     dump($v->name); //输出模型类名 DbName
}
打印出来查看对象里面本身每个模型类就存在一个私有 $name属性存放类名,当查询数据后数据库如果存在name字段,那么在模型类本身调用$model->name返回的是类的私有name属性,而不再是数据库name字段值。所以如果存在其他私有属性和数据库字段冲突也同样无法使用这种输出方式,只是name这个名称使用太普及而已,当然有其他方法转换一次来解决这种问题,当然这也是此调用数据方式的一种弊端。是否考虑对模型类的成员属性加上某种前缀标识呢?// 数据库对象池
    protected static $links = [];
    // 数据库配置
    protected $connection = [];
    // 数据库查询对象
    protected $query;
    // 当前模型名称
    protected $name;
    // 数据表名称
    protected $table;
    // 当前类名称
    protected $class;
    // 回调事件
    private static $event = [];
    // 错误信息
    protected $error;
    // 字段验证规则
    protected $validate;
    // 数据表主键 复合主键使用数组定义 不设置则自动获取
    protected $pk;
    // 数据表字段信息 留空则自动获取
    protected $field = [];
    // 只读字段
    protected $readonly = [];
    // 显示属性
    protected $visible = [];
    // 隐藏属性
    protected $hidden = [];
    // 追加属性
    protected $append = [];
    // 数据信息
    protected $data = [];
    // 记录改变字段
    protected $change = [];

    // 保存自动完成列表
    protected $auto = [];
    // 新增自动完成列表
    protected $insert = [];
    // 更新自动完成列表
    protected $update = [];
    // 是否需要自动写入时间戳 如果设置为字符串 则表示时间字段的类型
    protected $autoWriteTimestamp;
    // 创建时间字段
    protected $createTime = 'create_time';
    // 更新时间字段
    protected $updateTime = 'update_time';
    // 时间字段取出后的默认时间格式
    protected $dateFormat = 'Y-m-d H:i:s';
    // 字段类型或者格式转换
    protected $type = [];
    // 是否为更新数据
    protected $isUpdate = false;
    // 更新条件
    protected $updateWhere;
    // 当前执行的关联对象
    protected $relation;
    // 验证失败是否抛出异常
    protected $failException = false;
    // 全局查询范围
    protected $useGlobalScope = true;
    // 是否采用批量验证
    protected $batchValidate = false;
最佳答案
评论( 相关
后面还有条评论,点击查看>>