搜索结果,按访问权限过滤

问题描述

| 我已经成功实现了对我的客户主数据的搜索,并且它搜索了整个客户主数据。 我已登录代理商进行搜索。客户帐户与代理商相关联。我需要将搜索限制为与该代理相关联的客户(已登录)。 我该怎么做呢?     

解决方法

        好像您需要
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
    

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...