[英]Querying comma separated field?
我正在尝试基于逗号分隔的字段输出一个选择下拉选项,例如,如果用户被分配了 1 和 2 的 ID,那么我想输出位置 id 有 1 和 2:
用户表:id(等于 1)和 usergrouplocid,这是一个带有 (1,2) 的文本字段
位置表:id 其中 auto_increment 和 loc_id 见下面的图像:
我的查询如下:
$query = "SELECT room_location.*, client_room.*, users.* FROM room_location INNER JOIN client_room ON room_location.user_loc_id = client_room.id INNER JOIN users ON room_location.user_loc_id = users.userGroupLocID WHERE 1 IN (userGroupLocID) ORDER BY room_location.location";
上面的查询工作正常,但它只输出 1 的 id 在 usergrouplocid 中存在的位置,所以我如何让查询找到 1、2、3 或 4 等是否在 usergrouplocid 中。
以防万一你真的需要它现在排序而不重新设计你的数据库(我会)......
$ids = array(1,2,4);
$query = "SELECT room_location.*, client_room.*, users.* FROM room_location INNER JOIN client_room ON room_location.user_loc_id = client_room.id INNER JOIN users ON room_location.user_loc_id = users.userGroupLocID WHERE userGroupLocID REGEXP '(^|,)(".implode('|',$ids).")(,|$)' ORDER BY room_location.location";
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.