MyBatis学习(一)

打印 上一主题 下一主题

主题 556|帖子 556|积分 1668

一、什么是MyBatis

  根据官网介绍:
MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射;
MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作;
MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。
二、JDBC编程分析

  首先按照以往使用JDBC的方式来访问数据库:
JDBC实现数据库操作
  1.    public static void main(String[] args) {
  2.         Connection connection = null;
  3.         PreparedStatement preparedStatement = null;
  4.         ResultSet resultSet = null;
  5.         try {
  6.             //1.加载数据库驱动
  7.             Class.forName("com.mysql.jdbc.Driver");
  8.             //2.获取数据库连接
  9.             DriverManager.getConnection("jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8",
  10.                     "root", "root");
  11.             //3.定义sql语句
  12.             String sql = "select * from user where username = ?";
  13.             //4.获取预处理对象
  14.             preparedStatement = connection.prepareStatement(sql);
  15.             //5.设置参数
  16.             preparedStatement.setString(1, "王五");
  17.             //6.查询数据库
  18.             resultSet = preparedStatement.executeQuery();
  19.             //7.遍历查询的结果集
  20.             while (resultSet.next()) {
  21.                 System.out.println(resultSet.getString("id") + "--" +
  22.                         resultSet.getString("username"));
  23.             }
  24.         } catch (Exception e) {
  25.             e.printStackTrace();
  26.         } finally {
  27.             //8.释放资源
  28.             if (resultSet != null) {
  29.                 try {
  30.                     resultSet.close();
  31.                 } catch (SQLException e) {
  32.                     e.printStackTrace();
  33.                 }
  34.             }
  35.             if (preparedStatement != null) {
  36.                 try {
  37.                     preparedStatement.close();
  38.                 } catch (SQLException e) {
  39.                     e.printStackTrace();
  40.                 }
  41.             }
  42.             if (connection != null) {
  43.                 try {
  44.                     connection.close();
  45.                 } catch (SQLException e) {
  46.                     e.printStackTrace();
  47.                 }
  48.             }
  49.         }
  50.     }
复制代码
  虽然上述未经封装的JDBC代码可实现查询数据库记录的操作,但是分析上述代码可发现以下问题:

  • 数据库连接创建、释放会很频繁,从而导致系统资源的浪费;
  • SQL语句存在于代码中,而实际应用的过程中SQL语句可能时常发生变化,从而导致需要经常改动Java代码,造成代码不易维护;
  • 对结果集的解析存在硬编码(查询列名),SQL变化会导致解析代码变化,系统不易维护;
  针对上述存在的问题,可采用下述办法进行解决:

  • 可通过数据库连接池来解决数据库连接频繁创建、释放问题;
  • 将SQL语句独立于代码存放用来解决SQL语句在代码中硬编码的问题;
  • 将数据库记录封装成POJO对象进行解析来解决结果集的解析存在硬编码问题;
  而本次学习的MyBatis即可实现上述操作。
三、MyBatis快速入门


  • 创建Maven工程,导入相关依赖
pom.xml
  1.     <dependencies>
  2.         <dependency>
  3.             <groupId>org.mybatis</groupId>
  4.             <artifactId>mybatis</artifactId>
  5.             <version>3.4.5</version>
  6.         </dependency>
  7.         <dependency>
  8.             <groupId>junit</groupId>
  9.             <artifactId>junit</artifactId>
  10.             <version>4.10</version>
  11.             <scope>test</scope>
  12.         </dependency>
  13.         <dependency>
  14.             <groupId>mysql</groupId>
  15.             <artifactId>mysql-connector-java</artifactId>
  16.             <version>5.1.6</version>
  17.             <scope>runtime</scope>
  18.         </dependency>
  19.         <dependency>
  20.             <groupId>log4j</groupId>
  21.             <artifactId>log4j</artifactId>
  22.             <version>1.2.12</version>
  23.         </dependency>
  24.     </dependencies>
复制代码

  • 编写User实体类
User.java
  1. public class User implements Serializable {
  2.     private Integer id;
  3.     private String username;
  4.     private Date birthday;
  5.     private String sex;
  6.     private String address;
  7.     public Integer getId() {
  8.         return id;
  9.     }
  10.     public void setId(Integer id) {
  11.         this.id = id;
  12.     }
  13.     public String getUsername() {
  14.         return username;
  15.     }
  16.     public void setUsername(String username) {
  17.         this.username = username;
  18.     }
  19.     public Date getBirthday() {
  20.         return birthday;
  21.     }
  22.     public void setBirthday(Date birthday) {
  23.         this.birthday = birthday;
  24.     }
  25.     public String getSex() {
  26.         return sex;
  27.     }
  28.     public void setSex(String sex) {
  29.         this.sex = sex;
  30.     }
  31.     public String getAddress() {
  32.         return address;
  33.     }
  34.     public void setAddress(String address) {
  35.         this.address = address;
  36.     }
  37.     @Override
  38.     public String toString() {
  39.         return "User [id=" + id + ", username=" + username + ", birthday=" + birthday + ", " +
  40.                 "sex=" + sex + ", address=" + address + "]";
  41.     }
  42. }
复制代码

  • 编写持久层接口
UserDao.java
  1. public interface UserDao {
  2.     List<User> findAll();
  3. }
复制代码

  • 编写持久层接口的映射文件
UserDao.xml
  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
  3. <mapper namespace="com.dcyl.dao.UserDao">
  4.     <select id="findALL" resultMap="com.dcyl.domain.User">
  5.         select * from user
  6.     </select>
  7. </mapper>
复制代码

  • 编写SqlMapConfig.xml文件
SqlMapConfig.xml
  1. <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
  2.         "http://mybatis.org/dtd/mybatis-3-config.dtd">
  3. <configuration>
  4.    
  5.     <environments default="mysql">
  6.         
  7.         <environment id="mysql">
  8.             
  9.             <transactionManager type="JDBC"></transactionManager>
  10.             
  11.             <dataSource type="POOLED">
  12.                 <property name="driver" value="com.mysql.jdbc.Driver"/>
  13.                 <property name="url" value="jdbc:mysql://localhost:3306/mybatis"/>
  14.                 <property name="username" value="root"/>
  15.                 <property name="password" value="root"/>
  16.             </dataSource>
  17.         </environment>
  18.     </environments>
  19.    
  20.     <mappers>
  21.         <mapper resource="com/dcyl/dao/UserDao.xml"/>
  22.     </mappers>
  23. </configuration>
复制代码

  • 编写测试类
MyBatisTest
  1. public class MybatisTest {
  2.     public static void main(String[] args) throws Exception {
  3.         //1.读取配置文件
  4.         InputStream in = Resources.getResourceAsStream("SqlMapConfig.xml");
  5.         //2.创建SqlSessionFactory的构建者对象
  6.         SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
  7.         //3.使用构建者创建工厂对象SqlSessionFactory
  8.         SqlSessionFactory factory = builder.build(in);
  9.         //4.使用SqlSessionFactory生产SqlSession对象
  10.         SqlSession session = factory.openSession();
  11.         //5.使用SqlSession创建dao接口的代理对象
  12.         UserDao userDao = session.getMapper(UserDao.class);
  13.         //6.使用代理对象执行查询所有方法
  14.         List<User> users = userDao.findAll();
  15.         for (User user : users) {
  16.             System.out.println(user);
  17.         }
  18.         //7.释放资源
  19.         session.close();
  20.         in.close();
  21.     }
  22. }
复制代码
  至此关于MyBatis的入门案例已经完成,接下来就是关于MyBatis的具体细节的讲解。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

正序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

我可以不吃啊

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表