So, basically I have a field in a table from my database which contains some values separated by comma (something like: value1, value2, value3
). I need to check somehow if one or more of these values are contained in an array of values and retrieve the model(s). I'd like a solution using Eloquent Model Query to achieve this, if not possible with Model Query, then a Query Builder solution will be okay as well, or maybe something alternative.
Laravel 5:如何验证数据中是否包含以逗号分隔的数据库表字段中的值?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- douweicheng5532 2017-02-09 10:23关注
Tried to use a function inside the
where
statement where I loop the array of values and just query the model usinglike
operator to check if field value matches the values from the array and in the end I got something like this:$devices = explode(",", Input::get("devices")); $products = Product::where(function ($q) use ($devices) { foreach ($devices as $device) { $q->orWhere("compatible_devices", "like", "%" . $device . "%"); } })->get();
Works quite well so far.
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 kylin启动报错log4j类冲突
- ¥15 超声波模块测距控制点灯,灯的闪烁很不稳定,经过调试发现测的距离偏大
- ¥15 import arcpy出现importing _arcgisscripting 找不到相关程序
- ¥15 onvif+openssl,vs2022编译openssl64
- ¥15 iOS 自定义输入法-第三方输入法
- ¥15 很想要一个很好的答案或提示
- ¥15 扫描项目中发现AndroidOS.Agent、Android/SmsThief.LI!tr
- ¥15 怀疑手机被监控,请问怎么解决和防止
- ¥15 Qt下使用tcp获取数据的详细操作
- ¥15 idea右下角设置编码是灰色的