如何解决搜索结果,按访问权限过滤
| 我已经成功实现了对我的客户主数据的搜索,并且它搜索了整个客户主数据。 我已登录代理商进行搜索。客户帐户与代理商相关联。我需要将搜索限制为与该代理相关联的客户(已登录)。 我该怎么做呢?解决方法
好像您需要
LEFT JOIN
。您为什么不“ 0”正在讨论的表。例如:订单,销售代理,客户...
可能会工作。
, 您将需要将数据和sql语句的作用域限定为当前用户。
例如,假设您有一个表销售和一个表用户。从功能上讲,每个销售都属于一个用户。因此,销售表上应该有一个外键,例如user_id,它为每个销售行标识该销售所属的用户表中的行。
然后,在搜索销售时,应始终在其他动态过滤器之前添加\“ where user_id =?\”作为sql语句的第一个过滤器,并替换?。使用当前登录用户的ID。
这样,在搜索销售表时,所有筛选条件都将首先被划分为当前登录用户的范围。如果过滤条件否则会占用其他人的销售行,由于user_id过滤器,它将不再这样做。
如果您的销售除特定于代理商的销售外还与所有代理商都有关,那么它们可能会有一些标记,agent_id为0或可能为NULL,或者其他一些字段将其识别为所有人都可搜索。可以使用适当的括号轻松将其放入SQL语句中的第一个WHERE片段中,以将其保持在一起:
WHERE (agent_id = ? or agent_id IS NULL) AND other dynamic filter etc
WHERE (agent_id = ? or agent_id = 0) AND other dynamic filter etc
WHERE (agent_id = ? or all_agents_flag = 1) AND other dynamic filter etc
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。