
在 Laravel 开发中,经常需要在关联表中进行搜索,例如在一个 Lab 表中搜索 code 字段,同时也在关联的 Patient 表中搜索患者姓名。本文将详细介绍如何使用 Laravel 的 Eloquent ORM 实现这一功能。
首先,让我们回顾一下问题的核心:如何在查询 Lab 模型时,同时在关联的 Patient 模型中进行搜索,并返回符合条件的结果。
$lab = Lab::with(['patient' => function ($q) use ($search_query) {
$q->select('id', 'avatar', DB::raw('CONCAT(first_Name, " ", second_Name) AS name'))
->where('name', 'like', "%{$search_query}%")
->orWhereRaw("concat(first_name, ' ', second_name) like '%$search_query%' ");
}])
->select('id', 'code')
->Where('code', 'like', "%{$search_query}%")
->limit(5)
->get();上述代码的关键在于 with() 方法的使用。with() 方法允许我们在查询 Lab 模型时,预先加载关联的 patient 模型。 传递给 with() 方法的是一个关联关系的名称('patient')和一个闭包函数。
闭包函数接收一个查询构建器实例 $q 作为参数,我们可以使用 $q 来定义关联表的查询条件。
- use ($search_query): 这是非常重要的一点。因为闭包函数默认无法访问外部作用域的变量,所以需要使用 use 关键字将 $search_query 变量传递给闭包函数。
- $q->select('id', 'avatar', DB::raw('CONCAT(first_Name, " ", second_Name) AS name')): 这部分代码定义了我们想要从 Patient 表中选择的字段。 使用 DB::raw() 函数可以执行原始 SQL 语句,这里用于将 first_Name 和 second_Name 字段连接成一个名为 name 的新字段。
- ->where('name', 'like', "%{$search_query}%"): 这部分代码使用 where 子句来过滤 Patient 表的结果,只返回 name 字段包含 $search_query 的记录。
- ->orWhereRaw("concat(first_name, ' ', second_name) like '%$search_query%' "): 提供了另一种模糊匹配姓名的方式,避免大小写敏感等问题。
在 with() 方法之后,我们继续构建 Lab 模型的查询:
2088shop商城购物系统是商城系统中功能最全的一个版本:非会员购物、商品无限级分类、不限商品数量、商品多级会员定价、上货库存、Word在线编辑器、订单详情销售报表、商品评论、留言簿、管理员多级别、VIP积分、会员注册积分奖励、智能新闻发布、滚动公告、投票调查、背景图片颜色更换、店标上传、版权联系方式修改、背景音乐(好歌不断)、广告图片支持Flash、弹出浮动广告、搜索引擎关健词优化、图文友情联
- ->select('id', 'code'): 指定要从 Lab 表中选择的字段。
- ->Where('code', 'like', "%{$search_query}%"): 使用 where 子句来过滤 Lab 表的结果,只返回 code 字段包含 $search_query 的记录。
- ->limit(5): 限制返回的结果数量为 5 条。
- ->get(): 执行查询并返回结果。
注意事项:
- 确保 Lab 模型中定义了与 Patient 模型的关联关系 (例如 hasOne, hasMany, belongsTo, belongsToMany)。
- 根据实际需求调整查询条件和字段选择。
- 如果需要更复杂的搜索逻辑,可以使用更高级的查询构建器方法,例如 whereHas。
总结:
通过 with() 方法和闭包函数,我们可以方便地在 Laravel 中实现关联表的搜索。 关键在于理解 with() 方法的作用,以及如何使用闭包函数来定义关联表的查询条件。 结合 use 关键字,我们可以将外部变量传递给闭包函数,从而实现更灵活的搜索逻辑。









