公告管理(记录一次查询优化)

功能介绍:
支持管理员发布、删除、查看公告信息,支持用户查看公告并标记出已读/未读状态。

设计思路:
首先设计公告表T_NOTICE,使用noticeId作为主键并使用UUID作为默认生成规则,包含公告内容noticeContent、公告发布时间noticePublishTime。
其次设计关系表T_RELATION,使用relationId作为主键并使用UUID作为默认生成规则,包含noticeId、userId。

已读/未读实现原理:
通过T_RELATION表里是否包含{noticeId, userId}的数据来判断用户是否查看过该公告。

主要场景分析:
管理员创建公告,用户读取公告,T_RELATION表中生成一条记录。
管理员删除公告,开启数据库事务,首先删除T_NOTICE表中的公告,其次删除T_RELATION表中对应的数据,事务结束。

PS:
起初读取公告历史记录(包含用户读取状态)时,获取对应pageSize的T_NOTICE数据,并在for中循环查询获取该用户是否读取过这些公告,这样有了n+1次数据库的操作
DTO findOneByUserIdAndNoticeId(String userId, String noticeId)
优化:
批量返回T_RELATION数据,避免多次操作数据库。
List findByUserIdAndNoticeIdIn(String userId, List noticeIds)
这时候涉及到两个List的取值问题,可以简单的使用两次for循环解决,时间复杂度是n^2,我采用的是将返回的数据转化为map,noticeId作为key,假如能从map中取到值则已读,反之未读,时间复杂度为2*n。

  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
运行环境 操作系统:Windows XP。 Java平台:JDK 1.5。 Web服务器:Tomcat v 5.5.23,下载地址:http://tomcat.apache.org/。 数据库服务器:MySQL v 5.0.45,下载地址:http://www.mysql.com/。 开发平台:Eclipse SDK v 3.2.2,下载地址:http://www.eclipse.org/download/index.jsp。 Eclipse插件TomcatPlugins v 3.2.1,下载地址:http://www.eclipse-plugins.info/eclipse/index.jsp。 Eclipse插件ResourceBundleEditor v 0.7.7,下载地址:http://resourcebundleeditor.com/。 Eclipse插件MyEclipse v 5.5.1,下载地址:http://www.myeclipseide.com/ Spring 采用 2.0 版本 Hibernate 采用3.0版本 ============================ 请注意:如出现中文乱码,检查如下配置是否正确。 (1)MySql 数据库是否是utf-8 格式(在安装时选择支持多语言),数据是否正常。 (2)项目是否为utf-8格式(同时看看的源代码文件中,中文是否乱码)。 (3)JSP页面是否是utf-8 格式。 (4)在web.xml 是否配置了编码过滤器。 (5)数据源配置的url(?useUnicode=true&characterEncoding=UTF-8),具体请看项目实例。 如果上面5步都没问题,你就不存在中文乱码问题。 ============================== 数据库使用的是MySQL,其版本为5.0.45 版本。 数据库的用户名及密码均为root。 使用的时候,请参考附件数据库导入一节。或将需要用到的某章的数据库目录复制到“mysql安装根目录\data”文件夹下就可以了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值