SSM项目启动时访问数据库

思路:实现一个ServletListener,在web.xml中添加到ContextLoaderListener之后。listener中通过下文getBean,获取SqlSessionTemplate实例,调用mapperid。

    关键在于通过上下文获取SqlSessionTemplate实例。这里介绍两种方法:

    1、实现ApplicationContextAware接口。

import java.util.List;

import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;

import org.mybatis.spring.SqlSessionTemplate;
import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.stereotype.Component;

@Component
public class MyListener implements ServletContextListener,ApplicationContextAware{

    /**
     * 当前IOC
     */
    private static ApplicationContext applicationContext;

    /**
     * 设置当前上下文环境,此方法由spring自动装配
     */
    @Override
    public void setApplicationContext(ApplicationContext arg0)
            throws BeansException {
        applicationContext = arg0;
    }

    @Override
    public void contextInitialized(ServletContextEvent sce) {
        SqlSessionTemplate sst = (SqlSessionTemplate)applicationContext.getBean("sqlSession");
        List<SystemConfig> list = sst.selectList("selectAllCfgs");
        //TODO操作数据
    }

    @Override
    public void contextDestroyed(ServletContextEvent sce) {
    }
}

    注意要在类声明时加上@Component注解

    2、WebApplicationContextUtils.getRequiredWebApplicationContext(ServletContext sc)。

import java.util.List;

import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;

import org.mybatis.spring.SqlSessionTemplate;
import org.springframework.web.context.WebApplicationContext;
import org.springframework.web.context.support.WebApplicationContextUtils;

public class MyListener implements ServletContextListener {

    @Override
    public void contextInitialized(ServletContextEvent sce) {
        WebApplicationContext context = WebApplicationContextUtils.getRequiredWebApplicationContext(sce.getServletContext());
        SqlSessionTemplate sst = (SqlSessionTemplate) context.getBean("sqlSession");
        List<SystemConfig> list = sst.selectList("selectAllByMap");
        //TODO操作数据
    }

    @Override
    public void contextDestroyed(ServletContextEvent sce) {
    }

}


    web.xml

  <listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  </listener>
  <listener>
    <listener-class>**.MyListener</listener-class>
  </listener>



转载于:https://my.oschina.net/u/2293915/blog/472785

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值