如何根据 laravel eloquent orm 中的两列进行查询

Posted

技术标签:

【中文标题】如何根据 laravel eloquent orm 中的两列进行查询【英文标题】:How to query in terms of two columns in laravel eloquent orm 【发布时间】:2017-07-17 05:09:56 【问题描述】:

我需要帮助才能在 laravel 中进行查询。 我有三张桌子

1)Category(包含 id 和 name 列)。

2) 几何(包含 id 和 name 列)。

3) 实用(包含 id 和 name 列以及 Category_id,Geometry_id 列/键)

现在我想根据 Category_id 和 Geometry_id 搜索实用程序。 Practical.php 模型文件是..

    <?php

namespace App\Models;

use Illuminate\Foundation\Auth\User as Model;
use App\Models\Practical;

class Practical extends Model

    /**
     * The attributes that are mass assignable.
     *
     * @var array
     */
    protected $table='practical';
    protected $fillable = [
        'name',
    ];

    /**
     * The attributes that should be hidden for arrays.
     *
     * @var array
     */
    protected $hidden = [

    ];

    public function category()
    
        return $this->belongsTo('App\Models\Category');
    

    public function geometry()
    
        return $this->belongsTo('App\Models\Geometry');
    


类别和几何模型代码是

    <?php

namespace App\Models;

use Illuminate\Foundation\Auth\User as Model;
use App\Models\Geometry;

class Geometry extends Model

    /**
     * The attributes that are mass assignable.
     *
     * @var array
     */
    protected $table='geometry';
    protected $fillable = [
        'name',
    ];

    /**
     * The attributes that should be hidden for arrays.
     *
     * @var array
     */
    protected $hidden = [

    ];



     public function practical()
    
        return $this->hasMany('App\Models\Practical');
    



我知道如何只使用一个 ID.Category 或这样的几何进行查询..

$Categories=Category::where('id',1)->firstOrFail();

但我无法通过检查 Category 和 Geometry 的 id 来查询。

【问题讨论】:

【参考方案1】:

现在我想根据 Category_id 和 Geometry_id 搜索实用程序

如果您想按类别 ID 和几何 ID 搜索实用程序,只需进行简单查询:

Practical::where('category_id', $categoryId)
         ->where('geometry_id', $geometryId)
         ->get();

【讨论】:

以上是关于如何根据 laravel eloquent orm 中的两列进行查询的主要内容,如果未能解决你的问题,请参考以下文章

laravel Eloquent ORM - 如何获得编译查询?

如何在 Eloquent ORM laravel 中获取最后一个插入 ID

Laravel Eloquent ORM字段处理

Angular JS 与 Laravel - 如何绑定 Eloquent ORM 数组以查看

Laravel:如何使用 eloquent ORM 查找未经过身份验证的用户的信息?

如何在 Laravel Eloquent ORM 中获取插入的多行数据