使用MyBatis集成阿里巴巴druid连接池(不使用spring)

时间:2021-09-28 16:22:26
    • 在工作中发现mybatis默认的连接池POOLED,运行时间长了会报莫名其妙的连接失败错误。因此采用阿里巴巴的Druid数据源(码云链接 ,中文文档链接)。 mybatis更多数据源参考博客链接 。

      1 环境

      eclipse mars2 + maven3.3.9 + mysql5.7

      2 开发过程

      项目码云地址链接

      文件目录结构如下: 使用MyBatis集成阿里巴巴druid连接池(不使用spring)

      2.0 建立数据表

      在本地mysql数据库中建立名为test的database,并建立user表:


      CREATE DATABASE test default charset=utf8; CREATE TABLE `user` (
      `name` varchar(64) DEFAULT NULL,
      `age` int(11) DEFAULT NULL
      ) ENGINE=InnoDB DEFAULT CHARSET=utf8; insert into `user`(`name`,`age`) values ('叶莜落',27),('张三丰',128);

      2.1 建立一个maven工程,POM文件如下:

      <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
      <modelVersion>4.0.0</modelVersion>
      <groupId>com.yeyouluo.mybatis.druid</groupId>
      <artifactId>mybatis-druid</artifactId>
      <version>0.0.1-SNAPSHOT</version> <properties>
      <myabtis.version>3.4.1</myabtis.version>
      </properties> <dependencies>
      <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis</artifactId>
      <version>${myabtis.version}</version>
      </dependency>
      <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>5.1.30</version>
      </dependency>
      <dependency>
      <groupId>com.alibaba</groupId>
      <artifactId>druid</artifactId>
      <version>1.0.14</version>
      </dependency>
      </dependencies>
      </project>

      2.2 配置文件

      ①db.properties

      driver=com.mysql.jdbc.Driver
      url=jdbc:mysql://localhost:3306/test
      username=root
      password=root

      ②mybatis-config.xml

      <?xml version="1.0" encoding="UTF-8" ?>
      <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
      "http://mybatis.org/dtd/mybatis-3-config.dtd">
      <configuration>
      <!-- 引用db.properties配置文件 -->
      <properties resource="db.properties" /> <typeAliases>
      <typeAlias type="com.yeyouluo.mybatis.druid.utils.DruidDataSourceFactory"
      alias="DRUID" />
      </typeAliases> <!-- development : 开发模式 work : 工作模式 -->
      <environments default="work">
      <environment id="work">
      <transactionManager type="JDBC" />
      <!-- 配置数据库连接信息 -->
      <dataSource type="DRUID">
      <!-- value属性值引用db.properties配置文件中配置的值 -->
      <property name="driver" value="${driver}" />
      <property name="url" value="${url}" />
      <property name="username" value="${username}" />
      <property name="password" value="${password}" />
      </dataSource>
      </environment>
      </environments> <!-- mybatis的mapper文件,每个xml配置文件对应一个接口 -->
      <mappers>
      <mapper resource="mapper/userMapper.xml" />
      </mappers>
      </configuration>

      ③在resources目录下建立userMapper.xml

      <?xml version="1.0" encoding="UTF-8" ?>
      <!DOCTYPE mapper PUBLIC "-//ibatis.apache.org//DTD Mapper 3.0//EN"
      "http://ibatis.apache.org/dtd/ibatis-3-mapper.dtd">
      <mapper namespace="com.yeyouluo.mybatis.druid.dao.userDao">
      <select id="findAllUsers" resultType="com.yeyouluo.mybatis.druid.pojo.User">
      select * from user
      </select>
      </mapper>

      2.3 实体类 User

      package com.yeyouluo.mybatis.druid.pojo;
      
      public class User {
      
          private String name;
      private int age; public String getName() {
      return name;
      } public void setName(String name) {
      this.name = name;
      } public int getAge() {
      return age;
      } public void setAge(int age) {
      this.age = age;
      } @Override
      public String toString() {
      return "User [name=" + name + ", age=" + age + "]";
      } }

      2.4 工具类

      ①DruidDataSourceFactory.java

      package com.yeyouluo.mybatis.druid.utils;
      
      import java.sql.SQLException;
      import java.util.Properties;
      import javax.sql.DataSource;
      import org.apache.ibatis.datasource.DataSourceFactory;
      import com.alibaba.druid.pool.DruidDataSource; public class DruidDataSourceFactory implements DataSourceFactory {
      private Properties props; @Override
      public DataSource getDataSource() {
      DruidDataSource dds = new DruidDataSource();
      dds.setDriverClassName(this.props.getProperty("driver"));
      dds.setUrl(this.props.getProperty("url"));
      dds.setUsername(this.props.getProperty("username"));
      dds.setPassword(this.props.getProperty("password"));
      // 其他配置可以根据MyBatis主配置文件进行配置
      try {
      dds.init();
      } catch (SQLException e) {
      e.printStackTrace();
      }
      return dds;
      } @Override
      public void setProperties(Properties props) {
      this.props = props;
      }
      }

      ②MyBatisUtil.java

      package com.yeyouluo.mybatis.druid.utils;
      
      import java.io.InputStream;
      
      import org.apache.ibatis.io.Resources;
      import org.apache.ibatis.session.SqlSession;
      import org.apache.ibatis.session.SqlSessionFactory;
      import org.apache.ibatis.session.SqlSessionFactoryBuilder; public class MyBatisUtil {
      private static final String configFile = "mybatis-config.xml"; /**
      * 创建连接
      */
      public static SqlSession getSession() {
      SqlSession session = null;
      try {
      InputStream is = Resources.getResourceAsStream(configFile);
      SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
      session = factory.openSession();
      } catch (Exception e) {
      e.printStackTrace();
      }
      return session;
      } public static void closeSession(SqlSession session) {
      session.close();
      } public static void main(String[] args) {
      SqlSession session = MyBatisUtil.getSession();
      System.out.println(session);
      session.close();
      }
      }

      2.5 DAO

      ①接口IUserDao.java

      package com.yeyouluo.mybatis.druid.dao;
      
      import java.util.List;
      
      import com.yeyouluo.mybatis.druid.pojo.User;
      
      public interface IUserDao {
      public List<User> findAllUsers();
      }

      ②实现类UserDao.java

      package com.yeyouluo.mybatis.druid.dao.impl;
      
      import java.util.List;
      
      import org.apache.ibatis.session.SqlSession;
      
      import com.yeyouluo.mybatis.druid.dao.IUserDao;
      import com.yeyouluo.mybatis.druid.pojo.User;
      import com.yeyouluo.mybatis.druid.utils.MyBatisUtil; public class UserDao implements IUserDao { private static final String namespace = "com.yeyouluo.mybatis.druid.dao.userDao."; @Override
      public List<User> findAllUsers() {
      List<User> users = null;
      SqlSession session = MyBatisUtil.getSession();
      try {
      users = session.selectList(namespace + "findAllUsers", User.class);
      //注意:此处有陷阱,如果做了更新、插入或删除操作,必须使用:
      //session.commit();
      } catch (Exception e) {
      e.printStackTrace();
      }finally{
      MyBatisUtil.closeSession(session);
      }
      return users;
      } }

      2.6 测试类UserDaoTest.java

      package com.yeyouluo.mybatis.druid.dao.test;
      
      import java.util.List;
      
      import com.yeyouluo.mybatis.druid.dao.IUserDao;
      import com.yeyouluo.mybatis.druid.dao.impl.UserDao;
      import com.yeyouluo.mybatis.druid.pojo.User; public class UserDaoTest { public static void main(String[] args) {
      // TODO Auto-generated method stub
      IUserDao userDao = new UserDao();
      List<User> users= userDao.findAllUsers(); for(User user : users){
      System.out.println(user.toString());
      }
      } }

      3 结果

      使用MyBatis集成阿里巴巴druid连接池(不使用spring)

      4 参考

      Jar程序使用MyBatis集成阿里巴巴druid连接池

使用MyBatis集成阿里巴巴druid连接池(不使用spring)的更多相关文章

  1. Jar程序使用MyBatis集成阿里巴巴druid连接池

    在写jar程序,而不是web程序的时候,使用mybatis作为持久层,可以集成POOLED连接池,而阿里的druid不能用,确实很郁闷.不过有办法. 首先准备好数据库配置文件 然后对Druid进行一个 ...

  2. Mybatis 搭配 阿里druid连接池 连接 oracle 或 mysql

    DRUID介绍 DRUID是阿里巴巴开源平台上一个数据库连接池实现,它结合了C3P0.DBCP.PROXOOL等DB池的优点,同时加入了日志监控,可以很好的监控DB池连接和SQL的执行情况,可以说是针 ...

  3. MyBatis学习-使用Druid连接池将Maybatis整合到spring

    目录 前言 什么是Druid连接池 Druid可以做什么? 导入库包 连接oracle 连接mysql 导入mybatis 导入druid 导入spring-jdbc包 导入spring包 导入spr ...

  4. SpringBoot 配置阿里巴巴Druid连接池

    在Spring Boot下默认提供了若干种可用的连接池(dbcp,dbcp2, tomcat, hikari),当然并不支持Druid,Druid来自于阿里系的一个开源连接池,它提供了非常优秀的监控功 ...

  5. SpringBoot学习:整合MyBatis,使用Druid连接池

    项目下载地址:http://download.csdn.NET/detail/aqsunkai/9805821 (一)添加pom依赖: <!-- https://mvnrepository.co ...

  6. SpringBoot入门篇--整合mybatis&plus;generator自动生成代码&plus;druid连接池&plus;PageHelper分页插件

    原文链接 我们这一篇博客讲的是如何整合Springboot和Mybatis框架,然后使用generator自动生成mapper,pojo等文件.然后再使用阿里巴巴提供的开源连接池druid,这个连接池 ...

  7. spring&plus;mybatis&plus;c3p0数据库连接池或druid连接池使用配置整理

    在系统性能优化的时候,或者说在进行代码开发的时候,多数人应该都知道一个很基本的原则,那就是保证功能正常良好的情况下,要尽量减少对数据库的操作. 据我所知,原因大概有这样两个: 一个是,一般情况下系统服 ...

  8. springboot整合druid连接池、mybatis实现多数据源动态切换

    demo环境: JDK 1.8 ,Spring boot 1.5.14 一 整合durid 1.添加druid连接池maven依赖 <dependency> <groupId> ...

  9. springboot集成druid连接池

    使用druid连接池主要有几步: 1.添加jar和依赖 <groupId>org.mybatis.spring.boot</groupId> <artifactId&gt ...

随机推荐

  1. Lua 学习笔记(六)迭代器

    一.迭代器的定义      “迭代器”就是一种可以遍历一种集合中所有元素的机制.在Lua中迭代器以函数的形式表示,即没掉用一次函数,即可返回集合中的“下一个”元素.迭代器的实现可以借助于闭合函数实现, ...

  2. 浅谈javascript中的作用域

    首先说明一下:Js中的作用域不同于其他语言的作用域,要特别注意     JS中作用域的概念: 表示变量或函数起作用的区域,指代了它们在什么样的上下文中执行,亦即上下文执行环境.Javascript的作 ...

  3. Java第一阶段总结

    学习java已经一个多月的时间了,第一阶段总算完成了. 这中间遇到很多问题,通过问同学问学长,收获了很多,但也知道自己和其他同学相差很远.他们java第一阶段只用了不到一个月的时间,而我拖了很长时间, ...

  4. cocos2dx的模板容器简单使用(Vector&comma;Map&comma;Value)

    在cocos2dxv3.0beta之前存在顺序性容器cocos2d::CCArray,和cocos2d::CCDictionary.可是在新版本号之后这两个容器都将被cocos2d::Vector&l ...

  5. Java语法基础总结

    这次上课我们讲了Java语言中的枚举类型,并进行了一次课堂测试,测试代码如下: public class EnumTest { public static void main(String[] arg ...

  6. 盒子显隐,伪类边框,盒子阴影&comma;2d平面形变

    -盒子显隐 显隐的盒子尽量不影响其他盒子的布局 display:none; 消失的时候不占位置,显示的时候占位 opacity:0-1; 盒子透明度 overflow: hidden; 超出部分隐藏 ...

  7. P2464 &lbrack;SDOI2008&rsqb;郁闷的小J

    题目描述 小J是国家图书馆的一位图书管理员,他的工作是管理一个巨大的书架.虽然他很能吃苦耐劳,但是由于这个书架十分巨大,所以他的工作效率总是很低,以致他面临着被解雇的危险,这也正是他所郁闷的. 具体说 ...

  8. 自己开发chrome插件生成二维码

    摘要: 最近在开发微信项目时,需要在微信调试,所以经常会在微信中输入本地服务地址,输入起来特别麻烦,所以自己就想了想微信中的扫一扫,然后开发了这款chrome插件,将当前url生成二维码,用微信扫一扫 ...

  9. webpack&plus;sass&plus;vue 入门教程(三)

    十一.安装sass文件转换为css需要的相关依赖包 npm install --save-dev sass-loader style-loader css-loader loader的作用是辅助web ...

  10. 41-邮差送信&lpar;dfs&rpar;

    邮差送信 (15分)C时间限制:1 毫秒 |  C内存限制:3000 Kb题目内容: 有一个邮递员要在n个城市之间来回送信.但有的城市之间有大路相连而有的没有路.现在要由一个城市到另一个城市送信,中途 ...