thinkPHP5 关联查询的使用:hasOne/hasMany/belongsTo/belongsToMany

数据库中需要用到join连接查询时候,用thinkPHP框架的关联查询,可以有效的提高查询效率。(具体查询性能怎么样,咱也没试过,小伙伴们可以建两张数据量比较大的表,然后自己测试一下)

thinkPHP5手册:https://www.kancloud.cn/manual/thinkphp5/135196

hasOne: 一对一关联
这个没啥好解释的。数据之间的关联一对一。比如:一个用户表,一个最近登录表。我们设计之初,每个用户登录表只存储该用户最近一次的登录信息。

我们在SUser的模型中这样写两个方法:

	public function sLogin()
    {
        return $this->hasOne('SLogin', 'user_id');
    }
    public function getLogin()
    {
    	// SLogin 为关联表模型的名称。
        return $this
            ->hasWhere('sLogin', ['create_at' => ['<', '2020-05-15 00:00:00']], 'SUser.last_login_ip, SLogin.visit_ip')
//            ->with(['sLogin'])
            ->paginate(10);
    }

控制器里面进行调用:

	$result = (new SUser())->getRole();
	return json($result);

就可以看到效果了。
注意:
模型中with和hasWhere的区别是:
使用hasWhere: 可以添加关联表的查询条件,并且生成数据的格式和with不同
(下同)

hasMany: 一对多关联
数据之间的关系一对多,比如:一个用户有多个用户资源。
同样是SUser模型:

	public function uSource()
	{
		// 因为USource这个类不在当前命名空间,所以这样写。
	    return $this->hasMany('app\index\model\user\USource', 'user_id');
	}
	public function getSource()
	{
	     return $this
	         ->hasWhere('uSource', ['create_at' => ['<', '2020-05-01 00:00:00']], 'SUser.last_login_ip, USource.img_url')
	//            ->with(['uSource'])
	         ->where('last_login_ip', '=', '127.0.0.1')
	         ->paginate(10);
	 }

控制器不用写了吧。

belongsTo: 属于
当前方法的模型对应的数据表,属于另一个模型。相当于多对一。
比如:用户属于用户组。

	public function sGroup()
	{
	  	return $this->belongsTo('SGroup', 'group_id');
	}
	public function getGroup()
	{
	     return $this
	         ->hasWhere('sGroup', [], 'SGroup.group_name, SUser.*')
	//            ->with(['sGroup'])
	         ->where('last_login_ip', '=', '127.0.0.1')
	         ->paginate();
	 }

belongsToMany: 多对多关联
这个也不用解释吧。就是数据之间的关系是多对多。
比如:一个用户可能又多个角色,一个角色又包含多个用户。所以他们会有一张中间表,将角色和用户关联起来。

	public function userRoles()
    {
    	// 第一个参数是当前模型所关联的另一个模型,第二个参数是关联中间表的表名,第三个参数是中间表中另一个模型的数据主键,最后一个就是当前模型关联中间表的主键。
    	// 条件如果需要包含中间表的字段,用wherePivot
        return $this->belongsToMany('app\index\model\user\URoles', 's_relation', 'role_id', 'user_id')->wherePivot('type', 'eq', 1);
    }
    public function getRole()
    {
        return $this
            ->with(['userRoles'])
            ->where('last_login_ip', '=', '127.0.0.1')
            ->paginate(10);
    }

也可以多张表一起关联:

	public function getAll()
    {
        return $this
            ->with(['userRoles', 'sGroup', 'sLogin', 'uSource'])
            ->where('last_login_ip', '=', '127.0.0.1')
            ->paginate(10);
    }

就这。没了。

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
很抱歉您仍然遇到问题。根据您提供的错误信息,问题可能是因为 `open_basedir` 配置未生效或者存在其他权限问题。 请尝试以下步骤来解决问题: 1. 确认您正在编辑的 `php.ini` 文件是正确的文件。您可以通过在命令行中运行 `php --ini` 来查找当前正在使用的配置文件路径。 2. 确保您修改的是正确的 `php.ini` 文件,并且修改后的配置项生效。您可以通过在 PHP 代码中使用 `phpinfo()` 函数来验证 `open_basedir` 配置是否已更改。创建一个包含以下内容的 PHP 文件,并在浏览器中访问该文件: ```php <?php phpinfo(); ?> ``` 在打开的页面中搜索 `open_basedir`,确认它是否显示为您修改后的值。 3. 检查权限问题。确保 `/home/wwwroot/farmadmin/thinkphp/base.php` 文件及其所在目录的权限设置正确。除了 `public` 目录,还需要确保 `thinkphp` 目录和其内部文件的访问权限正确。您可以尝试将 `/home/wwwroot/farmadmin/thinkphp/base.php` 文件的权限设置为 777,以及其所在目录的权限设置为 755: ``` sudo chmod 777 /home/wwwroot/farmadmin/thinkphp/base.php sudo chmod 755 /home/wwwroot/farmadmin/thinkphp ``` 4. 重新启动 Nginx 和 PHP-FPM 服务: ``` sudo systemctl restart nginx sudo systemctl restart php-fpm ``` 请注意,为了安全起见,将文件和目录权限设置为 777 不是一个好的实践。一旦问题解决,请尽快将权限设置为更加安全的值。 如果问题仍然存在,请检查其他可能的配置文件(例如 `php-fpm.conf`)中是否存在其他限制或配置可能导致此错误。 希望这些步骤能帮助您解决问题。如果您有任何其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值