【SSM部落客(博客)项目实战09】初始化日志类别和日志日期信息数据

为了减轻服务器运行负担,所以我打算将一些基本信息初始化,存入缓存中,这样在进行一些初始化的操作的时候就不用老是查询了,极大的减轻了服务器的负担,同时用户体验会大大改善。

废话不多说我开始把核心的代码放出来,一起看下。

与之前的模块功能做法类似 ,唯一麻烦的是数据查询语句稍微难写一点。

查询语句:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.duruiqi.dao.BlogDao">

    <resultMap type="Blog" id="BlogResult">
        <result property="id" column="id"/>
        <result property="title" column="title"/>
        <result property="summary" column="summary"/>
        <result property="releaseDate" column="releaseDate"/>
        <result property="clickHit" column="clickHit"/>
        <result property="replyHit" column="replyHit"/>
        <result property="content" column="content"/>
        <result property="keyWord" column="keyWord"/>

    </resultMap>

    <select id="countList" resultMap="BlogResult">
        SELECT DATE_FORMAT(releaseDate,‘%Y年%m月‘) AS releaseDateStr,COUNT(*) AS blogCount  FROM t_blog GROUP BY DATE_FORMAT(releaseDate,‘%Y年%m月‘) ORDER BY  DATE_FORMAT(releaseDate,‘%Y年%m月‘) DESC;
    </select>

</mapper> 
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.duruiqi.dao.BlogTypeDao">

    <resultMap type="BlogType" id="BlogTypeResult">
        <result property="id" column="id"/>
        <result property="typeName" column="typeName"/>
        <result property="orderNo" column="orderNo"/>
    </resultMap>

    <select id="countList" resultMap="BlogTypeResult">
        SELECT t2.id,t2.typeName,COUNT(t1.id) AS blogCount FROM t_blog t1 RIGHT JOIN t_blogType  t2 ON t1.typeId=t2.id GROUP BY t2.typeName ORDER BY t2.orderNo;
    </select>

</mapper> 

监听控件

        BlogTypeService blogTypeService=(BlogTypeService) applicationContext.getBean("blogTypeService");
        List<BlogType> blogTypeCountList=blogTypeService.countList(); // 查询博客类别以及博客的数量
        application.setAttribute("blogTypeCountList", blogTypeCountList);

        BlogService blogService=(BlogService) applicationContext.getBean("blogService");
        List<Blog> blogCountList=blogService.countList(); // 根据日期分组查询博客
        application.setAttribute("blogCountList", blogCountList);

页面获取

<c:forEach var="blogTypeCount" items="${blogTypeCountList }">
                            <li><span><a href="#">${blogTypeCount.typeName }(${blogTypeCount.blogCount })</a></span></li>
                        </c:forEach>
<c:forEach var="blogCount" items="${blogCountList }">
                            <li><span><a href="#">${blogCount.releaseDateStr }(${blogCount.blogCount })</a></span></li>
                        </c:forEach>

页面效果:

基础信息初始化到此就结束了,很简单的,O(∩_∩)O哈哈~


【正在看本人博客的这位童鞋,我看你气度不凡,谈吐间隐隐有王者之气,日后必有一番作为!下面有个“顶”字,你就顺手把它点了吧(要先登录CSDN账号哦 )】


—–乐于分享,共同进步!

—–更多文章请看:http://blog.csdn.net/duruiqi_fx


时间: 2024-10-07 02:48:32

【SSM部落客(博客)项目实战09】初始化日志类别和日志日期信息数据的相关文章

基于SSM框架的博客系统(二)博主登录功能

一.        准备 1.数据库 创建表db_blogger: 1 DROP TABLE IF EXISTS `t_blogger`; 2 3 CREATE TABLE `t_blogger` ( 4 5 `id` INT(11) NOT NULL AUTO_INCREMENT, 6 7 `userName` VARCHAR(50) DEFAULT NULL, 8 9 `password` VARCHAR(100) DEFAULT NULL, 10 11 `profile` TEXT, 12

【SSH网上商城项目实战09】添加和更新商品类别功能的实现

上一节我们做完了查询和删除商品的功能,这一节我们做一下添加和更新商品的功能. 1. 添加商品类别 1.1 添加类别的UI设计 我们先说一下思路:首先当用户点击"添加商品"时,我们应该弹出一个"添加商品"的UI窗口(注意这里不是跳转到新的jsp,EasyUI只有一个页面),弹出这个"添加商品"的窗口后,应该锁住它父类的所有窗口(即点击其他地方无效,只能操作添加商品的窗口),等用户填好了信息后,在新弹出来的窗口上点击"添加"后,将

P2P互联网金融平台项目SSM+Redis+Mysql+Bootstrap+JQuery项目实战

系统组成 p2p网贷系统可分为三部分: 一.网站前台 网站平台交易系统主要完成整个平台的借款操作.展示.投标等功能.主要功能包括:用户注册.登录.借款标详细信息展示.发布借款.投资借款标等,同时贷款方完成还款操作,前台功能主要操作者为平台用户. 二.个人账户 贷款者和投资者的个人管理中心平台.主要包括:个人资料管理.账户管理.借款标和投资标的管理以及明细.邮箱认证.实名认证.vip申请.在线充值和提现等等功能. 三.借贷交易 借贷交易系统后台支撑系统主要是对整个借贷交易系统进行管理.维护等功能,

Ubuntu 出现apt-get: Package has no installation candidate问题 - 刘毅枫的博客 - 博客频道 - CSDN.NET

来源:http://blog.csdn.net/liuyifeng_510/article/details/7081490#1536434-hi-1-30578-42d97150898b1af15ddaae52f91f09c2

OC中的类别Category-协议Protocol-… - 韩俊强的博客 - 博客频道 - CSDN.NET

OC中的类别Category-协议Protocol- 类别(category)--通过使用类别,我们可以动态地为现有的类添加新方法,而且可以将类定义模块化地分不到多个相关文件中.通常只在类别中定义方法. 类别,接口部分的定义,通常该文件命名为已有"类+类别名.h" @interface 已有类 (类别名) //.......方法实现 @end #import #import "Buy.h" @interface Person : NSObject <<s

【python项目实战】BBS论坛(3)页面输出数据,及跳转

一.主页输出简单数据 核心代码; index.html     <div class="container">         {% block page-container %}             {{articles}}             {{ request.path }}         {% endblock %}     </div> <!-- /container --> views.py def index(request

【SSM部落客(博客)项目实战13】首页功能完善

这个模块总体有四个功能要实现,但是不难,所以我打算一起写出来了. 1按照日志类别查询日志 这块做法很简单 就是拼数据到后台进行查询 难点sql代码 大家可以看下 <select id="countList" resultMap="BlogTypeResult"> SELECT t2.id,t2.typeName,COUNT(t1.id) AS blogCount FROM t_blog t1 RIGHT JOIN t_blogType t2 ON t1.

Django实战之企业级博客

详情请交流  QQ  709639943 00.Python 从入门到精通 78节.2000多分钟.36小时的高质量.精品.1080P高清视频教程!包括标准库.socket网络编程.多线程.多进程和协程. 00.Django实战之用户认证系统 00.Django实战之企业级博客 00.深入浅出Netty源码剖析 00.NIO+Netty5各种RPC架构实战演练 00.JMeter 深入进阶性能测试体系 各领域企业实战 00.30天搞定大数据爬虫项目 00.零基础实战机器学学习 00.企业级实战

我的Android进阶之旅------&gt;经典的大牛博客推荐(排名不分先后)!!

本文来自:http://blog.csdn.net/ouyang_peng/article/details/11358405 今天看到一篇文章,收藏了很多大牛的博客,在这里分享一下 谦虚的天下 柳志超博客 Android中文Wiki AndroidStudio-NDK开发-移动开发团队谦虚的天下 - 博客园gundumw100博客 - android进阶分类文章列表 - ITeye技术网站CSDN博文精选:Android系列开发博客资源汇总 - CSDN.NET - CSDN资讯Android笔