站长百科 | 数字化技能提升教程 数字化时代生存宝典
首页
数字化百科
电子书
建站程序
开发
服务器
办公软件
开发教程
服务器教程
软件使用教程
运营教程
热门电子书
WordPress教程
宝塔面板教程
CSS教程
Shopify教程
导航
程序频道
推广频道
网赚频道
人物频道
网站程序
网页制作
云计算
服务器
CMS
论坛
网店
虚拟主机
cPanel
网址导航
WIKI使用导航
WIKI首页
最新资讯
网站程序
站长人物
页面分类
使用帮助
编辑测试
创建条目
网站地图
站长百科导航
站长百科
主机侦探
IDCtalk云说
跨境电商导航
WordPress啦
站长专题
网站推广
网站程序
网站赚钱
虚拟主机
cPanel
网址导航专题
云计算
微博营销
虚拟主机管理系统
开放平台
WIKI程序与应用
美国十大主机
编辑“
SpeedPHP/一表关联多表
”
人物百科
|
营销百科
|
网赚百科
|
站长工具
|
网站程序
|
域名主机
|
互联网公司
|
分类索引
跳转至:
导航
、
搜索
警告:
您没有登录。如果您做出任意编辑,您的IP地址将会公开可见。如果您
登录
或
创建
一个账户,您的编辑将归属于您的用户名,且将享受其他好处。
反垃圾检查。
不要
加入这个!
{{SpeedPHP top}} 在[[数据库]]表关联查询中,我们经常会遇到一个表关联多个表的情况,如在[[论坛]]的[[应用程序]]中,用户表需要关联附件表来获取用户头像的地址,另外也需要关联用户组表来获取用户的用户组和权限等等。在这种情况下,我们可以使用spLinker做多个关联的linker参数,这样来获取这些[[数据]]。 ==用户表模型== <pre><?php class m_user extends spModel { public $pk = 'uid'; public $table = 'user'; var $linker = array( 'avatar' => array( 'type' => 'hasone', // 一对一关联,一个用户只有一个头像 'map' => 'avatar', // 关联的标识 'mapkey' => 'uid', // 关联的字段 'fclass' => 'm_userimg', // 对应表的数据类是m_userimg 'fkey' => 'uid', // 对应表的关联字段 'enabled' => true ), </pre> <pre><span style="font-family: Arial, Verdana, sans-serif; white-space: normal; "> 'usergroup' => array( 'type' => 'hasmany', // 一对多关联,一个用户可能属于多个用户组 'map' => 'usergroup', // 关联的标识 'mapkey' => 'uid', // 关联的字段 'fclass' => 'm_group', // 对应表的数据类是m_group 'fkey' => 'uid', // 对应表的关联字段 'enabled' => true ),</span> </pre> 这里可以看到,[[代码]]已经实现了一个用户数据关联到其他两个表上面了。 补充一下: 1.如果需要关闭其中一个关联,可以通过 $obj->linker['avatar']['enabled'] = false;然后再执行spLinker,那么avatar的关联就会暂时消失了。 2.本文说的一表关联多表,指的是一表分别关联到别的几个表上,而不是“A表关联B表,然后B表关联C表”这种递进的关联,对于这种递进式的关联,目前也没有很好解决方案,建议是直接使用[[SQL]]语句来进行关联查找会有最大的效率。 ==参考来源== http://speedphp.com/manual.html {{SpeedPHP}} [[category:SpeedPHP|Y]]
摘要:
请注意,您对站长百科的所有贡献都可能被其他贡献者编辑,修改或删除。如果您不希望您的文字被任意修改和再散布,请不要提交。
您同时也要向我们保证您所提交的内容是您自己所作,或得自一个不受版权保护或相似自由的来源(参阅
Wordpress-mediawiki:版权
的细节)。
未经许可,请勿提交受版权保护的作品!
取消
编辑帮助
(在新窗口中打开)
本页使用的模板:
模板:SpeedPHP
(
编辑
)
模板:SpeedPHP top
(
编辑
)