问题描述
|
我已经成功实现了对我的客户主数据的搜索,并且它搜索了整个客户主数据。
我已登录代理商进行搜索。客户帐户与代理商相关联。我需要将搜索限制为与该代理相关联的客户(已登录)。
我该怎么做呢?
解决方法
好像您需要
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