站长百科 | 数字化技能提升教程 数字化时代生存宝典
首页
数字化百科
电子书
建站程序
开发
服务器
办公软件
开发教程
服务器教程
软件使用教程
运营教程
热门电子书
WordPress教程
宝塔面板教程
CSS教程
Shopify教程
导航
程序频道
推广频道
网赚频道
人物频道
网站程序
网页制作
云计算
服务器
CMS
论坛
网店
虚拟主机
cPanel
网址导航
WIKI使用导航
WIKI首页
最新资讯
网站程序
站长人物
页面分类
使用帮助
编辑测试
创建条目
网站地图
站长百科导航
站长百科
主机侦探
IDCtalk云说
跨境电商导航
WordPress啦
站长专题
网站推广
网站程序
网站赚钱
虚拟主机
cPanel
网址导航专题
云计算
微博营销
虚拟主机管理系统
开放平台
WIKI程序与应用
美国十大主机
编辑“
ThinkPHP开发指南-关联模型之关联查询
”
人物百科
|
营销百科
|
网赚百科
|
站长工具
|
网站程序
|
域名主机
|
互联网公司
|
分类索引
跳转至:
导航
、
搜索
警告:
您没有登录。如果您做出任意编辑,您的IP地址将会公开可见。如果您
登录
或
创建
一个账户,您的编辑将归属于您的用户名,且将享受其他好处。
反垃圾检查。
不要
加入这个!
<span style="border:1px solid #000; float:right; text-align:center; padding:6px;"><strong>导航:</strong>[[ThinkPHP开发指南-模型|上一页]]</span> <div style="clear:both;"></div> 由于性能问题,新版取消了自动关联查询机制,而统一使用relation方法进行关联操作,relation方法不但可以启用关联还可以控制局部关联操作,实现了关联操作一切尽在掌握之中。 '''PHP代码''' <pre> $User = D("User"); $user = $User->realtion(true)->find(1); </pre> 输出$user结果可能是类似于下面的数据: '''PHP代码''' <pre> array( 'id' => 1, 'account' => 'ThinkPHP', 'password' => '123456', 'Profile' => array( 'email' =>'liu21st@gmail.com', 'nickname' =>'流年', ), ) </pre> 我们可以看到,用户的关联数据已经被映射到数据对象的属性里面了。其中Profile就是关联定义的mapping_name属性。如果我们按照下面的凡事定义了as_fields属性的话, '''PHP代码''' <pre> protected $_link = array( 'profile'=>array( 'mapping_type' =>HAS_ONE, 'class_name' =>'Profile', 'foreign_key'=>'userId', 'as_fields'=>'email,nickname', ), ); </pre> 查询的结果就变成了下面的结果 : <pre> array( 'id' => 1, 'account' => 'ThinkPHP', 'password' => 'name', 'email' =>'liu21st@gmail.com', 'nickname' =>'流年', ) </pre> email和nickname两个字段已经作为user数据对象的字段来显示了。如果关联数据的字段名和当前数据对象的字段有冲突的话,怎么解决呢?我们可以用下面的方式来变化下定义: '''PHP代码''' <pre> 'as_fields'=>'email,nickname:username', </pre> 表示关联表的nickname字段映射成当前数据对象的username字段。默认会把所有定义的关联数据都查询出来,有时候我们并不希望这样,就可以给relation方法传入参数来控制要关联查询的。 '''PHP代码''' <pre> $User = D("User"); $user = $User->relation('Profile')->find(1); </pre> 关联查询一样可以支持select方法,如果要查询多个数据,并同时获取相应的关联数据,可以改成: '''PHP代码''' <pre> $User = D("User"); $list = $User->relation(true)->Select(); </pre> 如果希望在完成的查询基础之上 再进行关联数据的查询,可以使用 '''PHP代码''' <pre> $User = D("User"); $user = $User->find(1); // 表示对当前查询的数据对象进行关联数据获取 </pre> '''[[PHP]]代码''' <pre> $profile = $User->relationGet("Profile"); </pre> 事实上,除了当前的参考模型User外,其他的关联模型是不需要创建的。 [[category:ThinkPHP]]
摘要:
请注意,您对站长百科的所有贡献都可能被其他贡献者编辑,修改或删除。如果您不希望您的文字被任意修改和再散布,请不要提交。
您同时也要向我们保证您所提交的内容是您自己所作,或得自一个不受版权保护或相似自由的来源(参阅
Wordpress-mediawiki:版权
的细节)。
未经许可,请勿提交受版权保护的作品!
取消
编辑帮助
(在新窗口中打开)