我有一个用户数据表。一个用户可以“屏蔽”另一个用户,拒绝他们访问他们的任何帖子(比如“社交媒体网站”)。
如果 blockeduserids
'是逗号分隔列表的名称,其中包含的ID是整数,如何选择不阻止查看用户的用户?
我正在努力实现的非工作示例:
SELECT * FROM users WHERE [the blocked user's ID] NOT IN blockeduserids;
我有一个用户数据表。一个用户可以“屏蔽”另一个用户,拒绝他们访问他们的任何帖子(比如“社交媒体网站”)。
如果 blockeduserids
'是逗号分隔列表的名称,其中包含的ID是整数,如何选择不阻止查看用户的用户?
我正在努力实现的非工作示例:
SELECT * FROM users WHERE [the blocked user's ID] NOT IN blockeduserids;
1条答案
按热度按时间ftf50wuq1#
你可以用
FIND_IN_SET
在这里:但是,一般来说,在数据库表中保留逗号分隔的字符串是不可取的。更好的设计是将每个被阻止的用户id放在一个单独的表中。如果你有这样一个单独的表格,你可以写:
这可能会大大超过您当前的方法。