簡體   English   中英

查詢逗號分隔的字段?

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM