hasOne(WorkMember::class, 'userid', 'userid'); } /** * @return HasOne */ public function client() { return $this->hasOne(WorkClient::class, 'external_userid', 'userid'); } /** * @param $value * @return false|string */ public function getJoinTimeAttr($value) { return date('Y-m-d H:i:s', $value); } /** * 名称模糊搜索 * @param $query * @param $value */ public function searchNameLikeAttr($query, $value) { if ('' !== $value) { $query->where(function ($query) use ($value) { $query->whereIn('userid', function ($query) use ($value) { $query->name('work_client')->whereLike('name', '%' . $value . '%')->field(['external_userid']); })->whereOr('userid', 'in', function ($query) use ($value) { $query->name('work_member')->whereLike('name', '%' . $value . '%')->field(['userid']); }); }); } } }