一、需求:
在数据搜索时最常见的就是调用同一个方法查询,而查询的字段却可能是其中一个或其中的几个字段一起组合查询,例如:对列表的搜索,基本上都是几个字段随意组合搜索。那么在model里就需要判断有那个字段组合,怎么组合。
网上找了很久,Laravel群里也问了几个,都说没有写过,于是自己写个吧。话不多说,见代码:
function findByParam($param = array()) { $select = new Customer(); if (isset($param['name']) && '' != $param['name']) { $select = $select->where('customer.name', '=', $param['name']); } if (isset($param['phone']) && '' != $param['phone']) { $select = $select->where('customer.phone', '=', $param['phone']); } if (isset($param['email']) && '' != $param['email']) { $select = $select->where('customer.email', '=', $param['email']); } if (isset($param['tel']) && '' != $param['tel']) { $select = $select->where('customer.tel', '=', $param['tel']); } if (isset($param['qq']) && '' != $param['qq']) { $select = $select->where('customer.qq', '=', $param['qq']); } if (isset($param['IDCard']) && '' != $param['IDCard']) { $select = $select->where('customer.IDCard', '=', $param['IDCard']); } $customers = $select->leftJoin("member", function ($join) { $join->on("customer.memberID", "=", "member.id"); }) ->get(array( 'customer.id', 'customer.name', 'customer.sex', 'customer.tel', 'customer.phone', 'customer.address', 'customer.email', 'customer.qq', 'customer.headPic', 'customer.birthday', 'customer.IDCard', 'customer.enable', 'customer.memberID', 'customer.IDCard', 'customer.info', 'member.name as mname', 'member.discount' )); return json_encode($customers);
调用的时候,controller里只需要接收这些字段,无论它是否有值,直接加入到$param数组中查询就OK,例如:
function anyFindbyparam() { $name = Input::get('name'); $tel = Input::get('tel'); $phone = Input::get('phone'); $email = Input::get('email'); $qq = Input::get('qq'); $IDCard = Input::get('IDCard'); $customer = new Customer(); $customers = $customer->findByParam(array( 'name' => $name, 'tel' => $tel, 'phone' => $phone, 'email' => $email, 'qq' => $qq, 'IDCard' => $IDCard )); return $customers; }
以上这篇Laravel Eloquent ORM 多条件查询的例子就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。