初识Mybatis

一.概述

1.起源:
MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis 。2013年11月迁移到Github。iBATIS一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。iBATIS提供的持久层框架包括SQL Maps和Data Access Objects(DAOs).
2.介绍
MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java对象)映射成数据库中的记录。
3.特点:
(1)简单易学:本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件易于学习,易于使用,通过文档和源代码,可以比较完全的掌握它的设计思路和实现。
(2)灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。 sql写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。
(3)解除sql与程序代码的耦合:通过提供DAO层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。
(4)提供映射标签,支持对象与数据库的orm字段关系映射
(5)提供对象关系映射标签,支持对象关系组建维护
(6)提供xml标签,支持编写动态sql。

二.通过Mybatis实现单表的curd功能

1.添加mybatis的依赖,当前使用版本是3.4.6,除此之外还有junit和mysql的驱动依赖分别引入进来
代码实现如下:



          4.0.0

    com.qfedu
    Days21Mybatis
    1.0-SNAPSHOT

    
        
            mysql
            mysql-connector-java
            5.1.44
        
        
            junit
            junit
            4.12
        
        
            org.mybatis
            mybatis
            3.4.6
        
    

2.在resources目录下新增一个mybatis的配置文件,mybatis.xml






    
        
            
            
                
                
                
                
            
        
    
    
        
    

3.在bean的包下创建User.java文件

public class User {

    private int uid;
    private String username;
    private String password;
    private int age;
    private String addr;

    @Override
    public String toString() {
        return "User{" +
                "uid=" + uid +
                ", username='" + username + '\'' +
                ", password='" + password + '\'' +
                ", age=" + age +
                ", addr='" + addr + '\'' +
                '}';
    }

    public int getUid() {
        return uid;
    }

    public void setUid(int uid) {
        this.uid = uid;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public String getAddr() {
        return addr;
    }

    public void setAddr(String addr) {
        this.addr = addr;
    }
}

4.在resources的目录下创建UserMapper.xml(实现curd功能)文件




    

5.TestUser.java(测试类)

package com.qfedu.test;

import com.qfedu.pojo.User;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Test;

import java.io.IOException;
import java.sql.Connection;
import java.util.List;

public class TestUser {

    @Test
    public void testGetAllUsers(){

        /**
         *  1.  使用mybatis的配置文件以及SqlSessionFactoryBuilder建造者模式创建SqlSessionFactory对象
         *  2.  使用SqlSessionFactory对象的openSession()方法来得到一个SqlSession对象,用该对象即可完成对象的所有的crud操作
         *  3.  使用SqlSession对象来完成crud操作
         *  4.  关闭资源
         *
         */
        try {
            SqlSessionFactory sf = new SqlSessionFactoryBuilder().build(Resources.getResourceAsStream("mybatis.xml"));

            SqlSession session = sf.openSession();

            /**
             * session的crud方法("namespace.id");整个项目中的namespace.id必须唯一
             */
            List users = session.selectList("com.qfedu.pojo.UserMapper.selectUser");

            for (User u : users) {
                System.out.println(u);
            }

            if(session != null){
                session.close();
                session = null;
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

这是我在千峰线上学习的第21天,加油!!!

你可能感兴趣的:(初识Mybatis)