• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

[ThinkPHP]关联查询问题

php 搞代码 3年前 (2022-01-23) 12次浏览 已收录 0个评论
文章目录[隐藏]

使用ThinkPHP框架开发.

User模型里关联了personalapply表:
‘personalapply’ =>array(
‘mapping_type’=>self::HAS_MANY,
‘foreign_key’=>’uid’,
‘mapping_name’=>’personalapply’,
),

控制器里:根据前端接收的字段查询筛选(字段为personalapply表里字段)
//获取个人中心的申请信息
$limit_year = $_GET[‘limit_year’];
$loanuse = $_GET[‘loanuse’];
//申请表关联查询条件
$user=D(‘user’);
$applymap[‘limit_year’] = $limit_year;
$applymap[‘loanuse’] = $loanuse;
$userapply=$user->relation(‘personalapply’)->where($applymap)->select();//只能查询user表字段,不能查询personalapply表字段,

问题:想要user表跟personalapply表关联后怎么根据变量查询 personalapply里数据,得出关联后的查询数据。模型里condition只能写死!不能传变量。(我新手也看手册了,手册里没有,估计是我知道的函数不全,ThinkPHP不行我就使用PHP SQL查询了,求大神指出ThinkPHP实现的方法,THX!!)

回复讨论(解决方案)

建议你使用视图模型来查询:写一个自定义Model(如果是TP3.2版本,别忘了引入命名空间)

class UserPersonalapplyViewModel extends<b style="color:transparent">本文来源gao@!dai!ma.com搞$$代^@码!网!</b><strong>搞gaodaima代码</strong> ViewModel{	public $viewFields = array(		'User'=>array(			'User表需要取的字段1',			'字段2',			'字段3'		),		'personalapply'=>array(			'personalapply表需要取得字段1',			'字段2',			'字段3',			'_on'=>'User.主键=personalapply.uid',			'_type'=>'LEFT'		),	);} 

然后在控制器里实例化这个模型来取数据即可。

$UserPersonal = D('UserPersonalapplyViewModel');

建议你使用视图模型来查询:写一个自定义Model(如果是TP3.2版本,别忘了引入命名空间)

class UserPersonalapplyViewModel extends ViewModel{	public $viewFields = array(		'User'=>array(			'User表需要取的字段1',			'字段2',			'字段3'		),		'personalapply'=>array(			'personalapply表需要取得字段1',			'字段2',			'字段3',			'_on'=>'User.主键=personalapply.uid',			'_type'=>'LEFT'		),	);} 

然后在控制器里实例化这个模型来取数据即可。

$UserPersonal = D('UserPersonalapplyViewModel');

建议你使用视图模型来查询:写一个自定义Model(如果是TP3.2版本,别忘了引入命名空间)

class UserPersonalapplyViewModel extends ViewModel{	public $viewFields = array(		'User'=>array(			'User表需要取的字段1',			'字段2',			'字段3'		),		'personalapply'=>array(			'personalapply表需要取得字段1',			'字段2',			'字段3',			'_on'=>'User.主键=personalapply.uid',			'_type'=>'LEFT'		),	);} 

然后在控制器里实例化这个模型来取数据即可。

$UserPersonal = D('UserPersonalapplyViewModel');

建议你使用视图模型来查询:写一个自定义Model(如果是TP3.2版本,别忘了引入命名空间)

class UserPersonalapplyViewModel extends ViewModel{	public $viewFields = array(		'User'=>array(			'User表需要取的字段1',			'字段2',			'字段3'		),		'personalapply'=>array(			'personalapply表需要取得字段1',			'字段2',			'字段3',			'_on'=>'User.主键=personalapply.uid',			'_type'=>'LEFT'		),	);} 

然后在控制器里实例化这个模型来取数据即可。

$UserPersonal = D('UserPersonalapplyViewModel');

回复慢了,不好意思!我按你这种方法试一下!谢谢谢谢!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:[ThinkPHP]关联查询问题

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址