这种多级关联的搜索怎么做?

发布于 2022-09-12 22:58:02 字数 427 浏览 15 评论 0

需求是这样的:
1、一个多级关系,省/市/区/乡镇,每级都有一个自己的管理后台,管理员可以发通知等内容
2、上级可以给一个或者多个下级发通知,如:省上给某一个或者几个乡镇,一个或者几个县发通知
3、下级的工作人员要能看到上级发的通知
4、每个用户可以根据关键词搜索通知

我们目前做法, 建一张关联关系表,字段有:
通知主键ID,省ID,市ID,区ID,乡镇ID
表示某个通知,属于哪个行政等级。

比如某个区的工作人员查通知的时候,就会查到 区ID=自己的区ID or (区ID=0 and 市ID=自己的区ID ) or (市ID=0 and 省ID=自己的省ID ) 的所有通知的 ID,再根据 ID 去通知表查内容。

但是实现根据通知内容的关键词搜索,如果用 where in 查询 ,还需要要排序、分页,性能就太差了。

请教大神们,有什么好的思路吗?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

情绪失控 2022-09-19 22:58:02

分开啊。
某个工作人员级别<=镇,where 镇ID;
某个工作人员级别>镇,<=区,where 区ID;
某个工作人员级别>区,<=市,where 市ID;

//伪代码
NoticeQuery{
    private String levelField;
    private Long level;
}
<select>
select id from rel where #{levelField} = #{level}
</select>
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文