TP中可通过字段映射隐藏数据表的字段名

在ThinkPhP中,我们可以通过TP提供的一个关键字$_map来达到隐藏我们数据库中表的字段名的效果。

假设我们的User表里面有username和email字段,我们需要映射成另外的字段,定义方式如下:

例子如下:

namespace Home\Model;
use Think\Model;
Class UserModel extends Model{
     protected $_map = array(
         'name' =>'username', // 把表单中name映射到数据表的username字段
         'mail'  =>'email', // 把表单中的mail映射到数据表的email字段
     );}

这样,在表单里面就可以直接使用name和mail名称作为表单数据提交了。我们使用create方法创建数据对象的时候,会自动转换成定义的实际数据表字段。


但注意:使用关键字$_map定义字段映射是单向的。也就是说,不会把我们从数据库差到的字段名给映射为表单的其他名。

例如:

// 实例化User模型
$User = D('User');
$data = $User->find(3);
dump($data);

输出结果类似:

array(size=4) 
'id'      => int 3    
'<strong>username</strong>'=> string 'thinkphp'(length=8)   <span style="font-family: Arial, Helvetica, sans-serif;">//而不是name</span>
'<strong>email</strong>'   => string 'thinkphp@gmail.com' (length=18)   //而不是email 
'status'  => int 1
这个时候取出的data数据包含的是实际的username和email字段。


如果我们需要在数据获取的时候自动处理的话,设置开启READ_DATA_MAP参数;

'READ_DATA_MAP'=>true

这个时候,输出结果类似:

array(size=4) 
'id'      => int 3    
'<strong>name</strong>'=> string 'thinkphp'(length=8)   //用name 来代替username
'<strong>mail</strong>'   => string 'thinkphp@gmail.com' (length=18)   //用mail 代替了email
'status'  => int 1
也可以用 parseFieldsMap 来代替READ_DATA_MAP的效果 

// 实例化User模型
$User = D('User');
$data = $User->find(3);
$data = $User->parseFieldsMap($data);

通过上面的两种方式后,无论是find还是select方法读取后的data数据中就包含了name和mail字段数据了,而不再有username和email字段数据了。

这样,使用两个关键字就达到了隐藏我们数据表中的字段名。


来自:TP手册


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值