美文网首页
spring boot 整合 mybatis

spring boot 整合 mybatis

作者: xiaosecond | 来源:发表于2018-11-10 17:24 被阅读0次

    一、引入依赖

    <!-- Spring-Mybatis -->

    <dependency>

         <groupId>org.mybatis.spring.boot</groupId>

         <artifactId>mybatis-spring-boot-starter</artifactId>

        <version>1.3.0</version>

     </dependency>

    <!-- MySQL -->

    <dependency>

        <groupId>mysql</groupId>

        <artifactId>mysql-connector-java</artifactId>

    </dependency>

    <dependency>

            <groupId>org.springframework.boot</groupId>

            <artifactId>spring-boot-starter-web</artifactId>

    </dependency>

    <!-- data source -->

    <dependency>

        <groupId>com.alibaba</groupId>

        <artifactId>druid</artifactId>

        <version>1.1.6</version>

    </dependency>

    二、配置application.properties 

    ## 数据库配置

    ## 数据源

    spring.datasource.type = com.alibaba.druid.pool.DruidDataSource

    ## 数据库连接

    spring.datasource.url=jdbc:mysql://localhost:3306/testdb?useUnicode=true&characterEncoding=utf8

    ## 数据库用户名

    spring.datasource.username=root

    ## 数据库连接密码

    spring.datasource.password=123456

    ## 数据库连接驱动

    spring.datasource.driverClassName=com.mysql.jdbc.Driver

    ## 配置监控统计拦截filters

    spring.datasource.filters = stat

    ## 连接池最大使用连接数

    spring.datasource.maxActive = 20

    ## 初始化连接大小

    spring.datasource.initialSize = 3

    ## 获取连接最大等待时间

    spring.datasource.maxWait = 60000

    ## 连接池最小空闲

    spring.datasource.minIdle = 1

    ## 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒

    spring.datasource.timeBetweenEvictionRunsMillis = 60000

    ## 配置一个连接在池中最小生存的时间,单位是毫秒

    spring.datasource.minEvictableIdleTimeMillis = 300000

    spring.datasource.validationQuery = select 'x'

    spring.datasource.testWhileIdle = true

    spring.datasource.testOnBorrow = false

    spring.datasource.testOnReturn = false

    spring.datasource.poolPreparedStatements = true

    spring.datasource.maxOpenPreparedStatements = 20

    三、配置DruidConfig

    import com.alibaba.druid.pool.DruidDataSource;

    import com.alibaba.druid.support.http.StatViewServlet;

    import com.alibaba.druid.support.http.WebStatFilter;

    import org.springframework.beans.factory.annotation.Value;

    import org.springframework.boot.web.servlet.FilterRegistrationBean;

    import org.springframework.boot.web.servlet.ServletRegistrationBean;

    import org.springframework.context.annotation.Bean;

    import org.springframework.context.annotation.Configuration;

    import org.springframework.context.annotation.Primary;

    import java.sql.SQLException;

    /**

    * Created by panxiang on 2017-06-25.

    */

    @Configuration

    public class DruidConfig {

        @Value("${spring.datasource.url}")

        private String dbUrl;

        @Value("${spring.datasource.username}")

        private String username;

        @Value("${spring.datasource.password}")

        private String password;

        @Value("${spring.datasource.driverClassName}")

        private String driverClassName;

        @Value("${spring.datasource.initialSize}")

        private int initialSize;

        @Value("${spring.datasource.minIdle}")

        private int minIdle;

        @Value("${spring.datasource.maxActive}")

        private int maxActive;

        @Value("${spring.datasource.maxWait}")

        private int maxWait;

        @Value("${spring.datasource.timeBetweenEvictionRunsMillis}")

        private int timeBetweenEvictionRunsMillis;

        @Value("${spring.datasource.minEvictableIdleTimeMillis}")

        private int minEvictableIdleTimeMillis;

        @Value("${spring.datasource.validationQuery}")

        private String validationQuery;

        @Value("${spring.datasource.testWhileIdle}")

        private boolean testWhileIdle;

        @Value("${spring.datasource.testOnBorrow}")

        private boolean testOnBorrow;

        @Value("${spring.datasource.testOnReturn}")

        private boolean testOnReturn;

        @Value("${spring.datasource.poolPreparedStatements}")

        private boolean poolPreparedStatements;

        @Value("${spring.datasource.filters}")

        private String filters;

        @Bean

        public ServletRegistrationBean druidServlet() {

            ServletRegistrationBean reg = new ServletRegistrationBean();

            reg.setServlet(new StatViewServlet());

            reg.addUrlMappings("/druid/*");

            reg.addInitParameter("loginUsername", "admin");

            reg.addInitParameter("loginPassword", "123456");

            return reg;

        }

        @Bean

        public FilterRegistrationBean filterRegistrationBean() {

            FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean();

            filterRegistrationBean.setFilter(new WebStatFilter());

            filterRegistrationBean.addUrlPatterns("/*");

            filterRegistrationBean.addInitParameter("exclusions", "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");

            filterRegistrationBean.addInitParameter("profileEnable", "true");

            filterRegistrationBean.addInitParameter("principalCookieName", "USER_COOKIE");

            filterRegistrationBean.addInitParameter("principalSessionName", "USER_SESSION");

            return filterRegistrationBean;

        }

        @Bean

        @Primary

        public DruidDataSource druidDataSource() {

            DruidDataSource datasource = new DruidDataSource();

            datasource.setUrl(this.dbUrl);

            datasource.setUsername(username);

            datasource.setPassword(password);

            datasource.setDriverClassName(driverClassName);

            datasource.setInitialSize(initialSize);

            datasource.setMinIdle(minIdle);

            datasource.setMaxActive(maxActive);

            datasource.setMaxWait(maxWait);

            datasource.setTimeBetweenEvictionRunsMillis(timeBetweenEvictionRunsMillis);

            datasource.setMinEvictableIdleTimeMillis(minEvictableIdleTimeMillis);

            datasource.setValidationQuery(validationQuery);

            datasource.setTestWhileIdle(testWhileIdle);

            datasource.setTestOnBorrow(testOnBorrow);

            datasource.setTestOnReturn(testOnReturn);

            datasource.setPoolPreparedStatements(poolPreparedStatements);

            try {

                datasource.setFilters(filters);

            } catch (SQLException e) {

            }

            return datasource;

        }

    }

    四、配置SessionFactory

    import javax.sql.DataSource;

    import org.apache.ibatis.session.SqlSessionFactory;

    import org.mybatis.spring.SqlSessionFactoryBean;

    import org.mybatis.spring.SqlSessionTemplate;

    import org.mybatis.spring.annotation.MapperScan;

    import org.springframework.beans.factory.annotation.Autowired;

    import org.springframework.context.annotation.Bean;

    import org.springframework.context.annotation.Configuration;

    import org.springframework.core.io.support.PathMatchingResourcePatternResolver;

    import org.springframework.jdbc.datasource.DataSourceTransactionManager;

    import org.springframework.transaction.PlatformTransactionManager;

    import org.springframework.transaction.annotation.EnableTransactionManagement;

    import org.springframework.transaction.annotation.TransactionManagementConfigurer;

    /**

    * Created by panxiang on 2017-06-25.

    */

    @Configuration

    @EnableTransactionManagement

    @MapperScan(basePackages = SessionFactoryConfig.PACKAGE)

    public class SessionFactoryConfig implements TransactionManagementConfigurer {

        /**

        * mybatis 配置路径

        */

    //  static final String MYBATIS_CONFIG = "mybatis-config.xml";

        static final String PACKAGE = "com.tool.springBoot.dao";

        static final String MAPPER_LOCATION = "classpath:mapper/*.xml";

        static final String TYPEALIAS_PACKAGE = "com.tool.springBoot.vo";

        @Autowired

        private DataSource dataSource;

        /**

        * 创建sqlSessionFactoryBean 实例

        * 并且设置configtion 如驼峰命名.等等

        * 设置mapper 映射路径

        * 设置datasource数据源

        *

        * @return

        * @throws Exception

        */

        @Bean(name = "sqlSessionFactory")

        public SqlSessionFactoryBean createSqlSessionFactoryBean() throws Exception {

            SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();

            /** 设置mybatis configuration 扫描路径 */

    //        sqlSessionFactoryBean.setConfigLocation(new ClassPathResource(MYBATIS_CONFIG));

            /** 设置datasource */

            sqlSessionFactoryBean.setDataSource(dataSource);

            /** 设置typeAlias 包扫描路径 */

            sqlSessionFactoryBean.setTypeAliasesPackage(TYPEALIAS_PACKAGE);

            /**设置map映射文件路径*/

            sqlSessionFactoryBean.setMapperLocations(new PathMatchingResourcePatternResolver()

                    .getResources(SessionFactoryConfig.MAPPER_LOCATION));

            return sqlSessionFactoryBean;

        }

        @Bean

        public SqlSessionTemplate sqlSessionTemplate(SqlSessionFactory sqlSessionFactory) {

            return new SqlSessionTemplate(sqlSessionFactory);

        }

        @Bean

        @Override

        public PlatformTransactionManager annotationDrivenTransactionManager() {

            return new DataSourceTransactionManager(dataSource);

        }

    }

    五、配置 mapper 的xml文件

    <?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.tool.springBoot.dao.TestDao">

        <select id="findAll" resultType = "com.tool.springBoot.vo.StudentVO">

            select * from student;

        </select>

    </mapper>

    六、controller

    import org.springframework.beans.factory.annotation.Autowired;

    import org.springframework.stereotype.Controller;

    import org.springframework.web.bind.annotation.RequestMapping;

    import com.tool.springBoot.service.TestService;

    @Controller

    public class TestController {

    @Autowired

    private TestService  testService;

    @RequestMapping("/hello")

        public String index() {

            testService.testMybatis();

            return "hello";

        }

    }

    七、service

    import com.tool.springBoot.vo.User;

    public interface TestService {

            public String testMybatis();

    }

    @Component

    public class TestServiceImpl implements TestService{

            @Autowired

            private TestDao  testDao;

        @Override

        public void testMybatis() {

            testDao.findAll();

        }

    }

    八、dao

    import java.util.List;

    import org.apache.ibatis.annotations.Mapper;

    import com.tool.springBoot.vo.StudentVO;

    @Mapper

    public interface TestDao {

            public List<StudentVO> findAll();

    }

    相关文章

      网友评论

          本文标题:spring boot 整合 mybatis

          本文链接:https://www.haomeiwen.com/subject/qwzzxqtx.html