TP中可通过字段映射隐藏数据表的字段名
在ThinkPhP中,我们可以通过TP提供的一个关键字$_map来达到隐藏我们数据库中表的字段名的效果。
假设我们的User表里面有username和email字段,我们需要映射成另外的字段,定义方式如下:
例子如下:
namespace HomeModel;
use ThinkModel;
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手册
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。
- 上一篇: yii框架搜索后分页
- 下一篇: JForum论坛单点登录的几种实现方式 (CAS和Cookie)