hyperf关联子表查询主表数据

hyperf 关联子表查询主表数据
商品表 goods
商品语言表 goods_language
商品资源表 goods_image_map
商品表与【语言、资源】属于一对多的关系业务 1:查询语言表里面标题等于 *** 的商品主表数据
业务 2:查询出的子表数据,仅仅查询需要的数据
 

商品表模型
class GoodsModel extends Model
{

    //关联语言数据
    public function language()
    {
        return $this->hasMany(GoodsLanguageModel::class, 'goods_id', 'id');
    }
    //查询使用的配置
    public function goodsable(): \Hyperf\Database\Model\Relations\MorphTo
    {
        return $this->morphTo();
    }
    //关联资源数据
    public function image()
    {
        return $this->hasMany(GoodsImageMapModel::class, 'goods_id', 'id')->orderByRaw('image_type asc,sort_id asc');
    }

}

商品表模型
class GoodsModel extends Model
{

    //关联语言数据
    public function language()
    {
        return $this->hasMany(GoodsLanguageModel::class, 'goods_id', 'id');
    }
    //查询使用的配置
    public function goodsable(): \Hyperf\Database\Model\Relations\MorphTo
    {
        return $this->morphTo();
    }
    //关联资源数据
    public function image()
    {
        return $this->hasMany(GoodsImageMapModel::class, 'goods_id', 'id')->orderByRaw('image_type asc,sort_id asc');
    }

}

商品资源表
class GoodsImageMapModel extends Model
{

}


查询实现
use Hyperf\Database\Model\Builder;
use Hyperf\Database\Model\Relations\Relation;

class Test
{
    //根据商品ID和语言子表的标题进行查询商品数据
    public function search(string $language,string $title,array $goodsIdList,int $status)
    {
        $model = GoodsModel::query();
        //主表上架状态
        if($status){
            $model = $model->where('status','=',1);
        }
        //主表ID范围
        if($goodsIdList){
            $model = $model->whereIn('id',$goodsIdList);
        }
        //筛选子表的语言标识的字段范围
        $languageRange = array_unique([$language,Context::get('mainLanguageCode')]);

        if($title&&$title=urldecode($title)){
            //查询子表里面包含$title的主表数据,并且在语言范围的
            $model = $model->whereHas('language',function(Builder $query)use($title,$languageRange){
                $query->whereIn('language',$languageRange)->where('title','=',$title);
            });
        }
        //获取到的语言数据有范围限制,资源数据有筛选条件和排序
        return $model->with([
            "language" => function(Relation $relation)use($languageRange){
                return $relation->getQuery()->whereIn('language',$languageRange)->select(['id','goods_id','language','title','description']);
            },
            'image'=>function(Relation $relation){
                return $relation->getQuery()->where('resources_type','=',1)->orderByRaw('image_type asc,sort_id asc')->select(['id','goods_id','resources_id','sort_id','image_type']);
            }])->select(['id','status','shop_id'])->get()->toArray();

    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Hyperf 中,可以使用 `Hyperf\DbConnection\Db::query()` 方法来执行协程 MySQL 查询。该方法返回一个协程对象,使用 `await` 关键字来等待查询结果。以下是一个示例: ``` use Hyperf\DbConnection\Db; // 在协程中执行 MySQL 查询 $results = await Db::query('SELECT * FROM `users` WHERE `status` = ?', [1]); ``` 在上面的示例中,`Db::query()` 方法接受两个参数:SQL 查询语句和查询参数。查询参数可以是一个数组,其中的值将被自动转义和引用,以避免 SQL 注入攻击。 需要注意的是,执行 MySQL 查询时需要在 `config/autoload/databases.php` 中配置数据库连接信息。例如,以下是一个 MySQL 数据库连接的示例配置: ``` return [ 'default' => [ 'driver' => env('DB_DRIVER', 'mysql'), 'host' => env('DB_HOST', 'localhost'), 'port' => env('DB_PORT', 3306), 'database' => env('DB_DATABASE', 'test'), 'username' => env('DB_USERNAME', 'root'), 'password' => env('DB_PASSWORD', ''), 'charset' => env('DB_CHARSET', 'utf8mb4'), 'collation' => env('DB_COLLATION', 'utf8mb4_general_ci'), 'pool' => [ 'min_connections' => 1, 'max_connections' => 10, 'wait_timeout' => 3.0, ], ], ]; ``` ### 回答2: Hyperf协程是一种基于PHP协程的轻量级并发框架,可以利用高效的协程进行MySQL查询。在Hyperf中使用协程进行MySQL查询有以下几个步骤: 1. 配置MySQL连接:在Hyperf的配置文件中,设置MySQL的连接参数,包括主机名、端口号、用户名、密码、数据库名等。 2. 使用协程方式连接MySQL:Hyperf提供了`Hyperf\Database\Pool\Pool::get()`方法来获取MySQL连接池的实例,然后使用协程的方式连接MySQL数据库。 3. 执行查询语句:使用协程的方式执行MySQL查询语句,可以使用`HYPERF_COMMAND`宏定义来包裹查询语句,以实现协程查询的功能。 4. 获取查询结果:使用协程的方式获取查询的结果,可以使用`$connection->fetchAll()`方法来获取查询结果集。 5. 释放连接:在查询完毕后,需要手动释放连接,使用`$connection->release()`方法将连接放回连接池,以便其他协程可以复用连接。 通过上述步骤,可以在Hyperf中实现使用协程进行MySQL查询的功能。由于协程的特性,可以提高查询的性能和响应速度,同时减少资源的消耗。 ### 回答3: Hyperf是一个基于Swoole的高性能框架,可以使用协程来进行MySQL查询。 在Hyperf中,使用协程进行MySQL查询非常简单。首先,我们需要确保项目中安装了`hyperf/database`组件。 接下来,我们可以在控制器或服务类中使用依赖注入来引入数据库连接池对象Pool,然后调用query方法进行查询。这样我们就可以在协程中执行MySQL查询操作。 下面是一个简单的示例: ``` use Hyperf\Database\Pool\Pool; use Hyperf\Database\ConnectionInterface; class SomeService { /** * @var ConnectionInterface */ private $connection; public function __construct(Pool $pool) { $this->connection = $pool->getConnection(); } public function query() { $result = $this->connection->select('SELECT * FROM users'); return $result; } } ``` 在这个例子中,我们通过依赖注入引入了数据库连接池对象Pool,并获取了一个数据库连接对象ConnectionInterface。 然后,我们调用了ConnectionInterface对象的select方法,传入了一个简单的查询语句,这里是选择所有的用户数据查询结果会以数组的形式返回给我们。 需要注意的是,在Hyperf中使用协程进行MySQL查询时,我们无需手动创建和释放连接,连接池会自动处理连接的获取和归还。 通过以上例子,我们可以看到Hyperf框架非常方便地支持了协程MySQL查询,使得我们可以在高性能的基础上,更加便捷地操作数据库。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值