1、认识Mybatis

MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架。 MyBatis 消除了几乎所有的 JDBC 代码和参数的手工设置以及对结果集的检索。 MyBatis 可以使用简单的XML 或注解用于配置和原始映射,将接口和 Java 的 POJO( Plain Old Java Objects,普通的Java 对象)映射成数据库中的记录.

1)MyBATIS 目前提供了三种语言实现的版本,包括:Java、.NET以及Ruby。(我主要学习java,就讲java的使用)
  2)它提供的持久层框架包括SQL Maps和Data Access Objects(DAO)。
  3)mybatis与hibernate的对比?

mybatis提供一种“半自动化”的ORM实现。
   这里的“半自动化”,是相对Hibernate等提供了全面的数据库封装机制的“全自动化”ORM实现而言,“全自动”ORM实现了POJO和数据库表之间的映射,以及 SQL 的自动生成和执行。

而mybatis的着力点,则在于POJO与SQL之间的映射关系。

2、基于配置文件的CRUD    使用的mybatis的版本是3.1.1

User.java

public class User {

private Integer id;
    
    private String username;
    
    private String password;

public Integer getId() {
        return id;
    }

public void setId(Integer id) {
        this.id = id;
    }

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 User() {
        super();
        // TODO Auto-generated constructor stub
    }

public User(Integer id, String username, String password) {
        super();
        this.id = id;
        this.username = username;
        this.password = password;
    }
    
    public User(String username, String password) {
        super();
        this.username = username;
        this.password = password;
    }  
}

User.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.sram.pojo.User">
    <!-- 插入语句 -->
    <insert id="add" parameterType="com.sram.pojo.User">
        INSERT INTO t_user(USERNAME,PASSWORD) VALUES(#{username},#{password});
    </insert>
    <!-- 更新语句 -->
    <update id="update" parameterType="com.sram.pojo.User">
        UPDATE t_user SET USERNAME=#{username},PASSWORD=#{password} WHERE ID=#{id};
    </update>
    <!-- 删除语句 -->
    <delete id="delete" parameterType="int">
        DELETE FROM t_user WHERE ID=#{id};
    </delete>
    <!-- 查询集合 -->
    <select id="list" resultType="com.sram.pojo.User">
        SELECT ID,USERNAME,PASSWORD FROM t_user;
    </select>
    <!-- 查询单个 -->
    <select id="load" resultType="com.sram.pojo.User" parameterType="int">
        SELECT ID,USERNAME,PASSWORD FROM t_user where ID=#{id};
    </select>
</mapper>

Mybatis获取session的工具类MybatisUtil

public class MyBatiesUtil {

private static SqlSessionFactory factory;
    
    //加载一次配置文件
    static{
        try {
            InputStream in = Resources.getResourceAsStream("mybatis-config.xml");
            factory = new SqlSessionFactoryBuilder().build(in);
        } catch (IOException e) {
            e.printStackTrace();
        }
        
    }
    
    //得到sqlSession
    public static SqlSession getSqlSession(){
        return factory.openSession();
    }
}

数据库的配置文件jdbc.properties

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url = jdbc\:mysql\://localhost\:3306/mybatis?useUnicode\=true&characterEncoding\=utf-8
jdbc.username = root
jdbc.password = rrb

日志配置文件log4j.properties

#--------------------------------   
#  
log4j.rootLogger=INFO, stdout  
#log4j.logger.test=info  
#log4j.logger.org.apache.jasper = DEBUG  
#log4j.logger.org.apache.catalina.startup.TldConfig = DEBUG  
#log4j.logger.org.apache.catalina.session.ManagerBase = DEBUG  
 
#log4j.logger.com.fiscal = DEBUG  
#log4j.logger.com.system = DEBUG  
 
log4j.logger.com.ibatis = DEBUG  
log4j.logger.com.ibatis.common.jdbc.SimpleDataSource = DEBUG  
log4j.logger.com.ibatis.common.jdbc.ScriptRunner = DEBUG  
log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate = DEBUG  
log4j.logger.java.sql.Connection = DEBUG  
log4j.logger.java.sql.Statement = DEBUG  
log4j.logger.java.sql.PreparedStatement = DEBUG
log4j.logger.java.sql.ResultSet = INFO  
 
log4j.appender.stdout=org.apache.log4j.ConsoleAppender   
 
#log4j.appender.fileout=org.apache.log4j.RollingFileAppender  
#log4j.appender.fileout.File=e:/log/ibatis.log   
#log4j.appender.fileout.MaxFileSize=10000KB

log4j.appender.stdout.layout=org.apache.log4j.PatternLayout   
#log4j.appender.stdout.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss} :%m%n   
#log4j.appender.fileout.layout=org.apache.log4j.PatternLayout   
#log4j.appender.fileout.layout.ConversionPattern=[%-5p]_%d{yyyy-MM-dd HH:mm:ss} :%m%n  
 
#log4j.appender.stdout.layout=org.apache.log4j.SimpleLayout   
 
# log4j.logger.org=info

Mybatis配置文件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>
    <!-- 读取配置文件 -->
    <properties resource="jdbc.properties"></properties>
    <environments default="development">
        <environment id="development" >
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="${jdbc.driver}"/>
                <property name="url" value="${jdbc.url}"/>
                <property name="username" value="${jdbc.username}"/>
                <property name="password" value="${jdbc.password}"/>
            </dataSource>
        </environment>
    </environments>
    <!-- 将mapper文件加入到配置文件中 -->
    <mappers>
        <mapper resource="com/sram/pojo/User.xml"/>
    </mappers>
</configuration>

测试CRUD的测试类

public class UserTest {

//测试配置添加方法
    @Test
    public void add(){
        
        //得到sqlSession
        SqlSession session = MyBatiesUtil.getSqlSession();
        
        try {
            User user = new User("张三","123");
            
            session.insert(User.class.getName()+".add",user);
            //事务提交
            session.commit();
            
            session.close();
        } catch (Exception e) {
            e.printStackTrace();
            session.rollback();
        }
        
    }
    //测试配置更新方法
    @Test
    public void update(){
        
        //得到sqlSession
        SqlSession session = MyBatiesUtil.getSqlSession();
        
        try {
            User user = new User(9,"李四","567");
            
            session.update(User.class.getName()+".update",user);
            
            //事务提交
            session.commit();
            
            session.close();
        } catch (Exception e) {
            e.printStackTrace();
            session.rollback();
        }
        
    }
    //测试配置删除方法
    @Test
    public void delete(){
        
        //得到sqlSession
        SqlSession session = MyBatiesUtil.getSqlSession();
        
        try {
            
            session.delete(User.class.getName()+".delete",10);
            
            //事务提交
            session.commit();
            
            session.close();
        } catch (Exception e) {
            e.printStackTrace();
            session.rollback();
        }
        
    }
    //测试配置查询集合方法
    @Test
    public void list(){
        
        //得到sqlSession
        SqlSession session = MyBatiesUtil.getSqlSession();
        List<User> list = null;
        try {
            
            list = session.selectList(User.class.getName()+".list");
            
            System.out.println(list);
            //事务提交
            session.commit();
            
            session.close();
        } catch (Exception e) {
            e.printStackTrace();
            session.rollback();
        }
        
    }
    //测试配置查询单个方法
    @Test
    public void load(){
        
        //得到sqlSession
        SqlSession session = MyBatiesUtil.getSqlSession();
        try {
            
            User user = session.selectOne(User.class.getName()+".load",9);
            
            System.out.println(user.getUsername());
            //事务提交
            session.commit();
            
            session.close();
        } catch (Exception e) {
            e.printStackTrace();
            session.rollback();
        }
        
    }
}

3、基于注解的CRUD 使用的mybatis的版本是3.1.1

User.java

public class User {

private Integer id;
    
    private String username;
    
    private String password;

public Integer getId() {
        return id;
    }

public void setId(Integer id) {
        this.id = id;
    }

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 User() {
        super();
        // TODO Auto-generated constructor stub
    }

public User(Integer id, String username, String password) {
        super();
        this.id = id;
        this.username = username;
        this.password = password;
    }
    
    public User(String username, String password) {
        super();
        this.username = username;
        this.password = password;
    }
}

UserMapper.java

public interface UserMapper {

@Insert("INSERT INTO t_user(USERNAME,PASSWORD) VALUES(#{username},#{password})")
    public void addUser(User user);
    
    @Update("UPDATE t_user SET USERNAME=#{username},PASSWORD=#{password} WHERE ID=#{id}")
    public void update(User user);
    
    @Delete("DELETE FROM t_user WHERE ID=#{id}")
    public void delete(int id);
    
    @Select("SELECT ID,USERNAME,PASSWORD FROM t_user")
    public List<User> list();
    
    @Select("SELECT ID,USERNAME,PASSWORD FROM t_user where ID=#{id}")
    public User load(int id);
}

mybatis获取session的工具类 MybatisUtils.java

public class MyBatisUtil {

private static SqlSessionFactory factory;
    
    //加载一次配置文件
    static{
        try {
            InputStream in = Resources.getResourceAsStream("mybaties-config.xml");
            factory = new SqlSessionFactoryBuilder().build(in);
        } catch (IOException e) {
            e.printStackTrace();
        }
        
    }
    
    //得到sqlSession
    public static SqlSession getSqlSession(){
        return factory.openSession();
    }

数据库的配置文件jdbc.properties

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url = jdbc\:mysql\://localhost\:3306/mybatis?useUnicode\=true&characterEncoding\=utf-8
jdbc.username = root
jdbc.password = rrb

日志配置文件log4j.properties

#--------------------------------   
#  
log4j.rootLogger=INFO, stdout  
#log4j.logger.test=info  
#log4j.logger.org.apache.jasper = DEBUG  
#log4j.logger.org.apache.catalina.startup.TldConfig = DEBUG  
#log4j.logger.org.apache.catalina.session.ManagerBase = DEBUG  
 
#log4j.logger.com.fiscal = DEBUG  
#log4j.logger.com.system = DEBUG  
 
log4j.logger.com.ibatis = DEBUG  
log4j.logger.com.ibatis.common.jdbc.SimpleDataSource = DEBUG  
log4j.logger.com.ibatis.common.jdbc.ScriptRunner = DEBUG  
log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate = DEBUG  
log4j.logger.java.sql.Connection = DEBUG  
log4j.logger.java.sql.Statement = DEBUG  
log4j.logger.java.sql.PreparedStatement = DEBUG
log4j.logger.java.sql.ResultSet = INFO  
 
log4j.appender.stdout=org.apache.log4j.ConsoleAppender   
 
#log4j.appender.fileout=org.apache.log4j.RollingFileAppender  
#log4j.appender.fileout.File=e:/log/ibatis.log   
#log4j.appender.fileout.MaxFileSize=10000KB

log4j.appender.stdout.layout=org.apache.log4j.PatternLayout   
#log4j.appender.stdout.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss} :%m%n   
#log4j.appender.fileout.layout=org.apache.log4j.PatternLayout   
#log4j.appender.fileout.layout.ConversionPattern=[%-5p]_%d{yyyy-MM-dd HH:mm:ss} :%m%n  
 
#log4j.appender.stdout.layout=org.apache.log4j.SimpleLayout   
 
# log4j.logger.org=info

mybatis配置文件mybatis-confg.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>
    <!-- 读取配置文件 -->
    <properties resource="jdbc.properties"></properties>
    <environments default="development">
        <environment id="development" >
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="${jdbc.driver}"/>
                <property name="url" value="${jdbc.url}"/>
                <property name="username" value="${jdbc.username}"/>
                <property name="password" value="${jdbc.password}"/>
            </dataSource>
        </environment>
    </environments>
    <!-- 将mapper文件加入到配置文件中 -->
    <mappers>
        <mapper class="com.sram.mapper.UserMapper"/>
    </mappers>
</configuration>

测试类

public class UserTest {

//测试注解添加方法
    @Test
    public void add(){
        
        //得到sqlSession
        SqlSession session = MyBatiesUtil.getSqlSession();
        
        try {
            User user = new User("张三","123");
            
            session.getMapper(UserMapper.class).addUser(user);
            
            //事务提交
            session.commit();
            
            session.close();
        } catch (Exception e) {
            e.printStackTrace();
            session.rollback();
        }
        
    }
    //测试注解更新方法
    @Test
    public void update(){
        
        //得到sqlSession
        SqlSession session = MyBatiesUtil.getSqlSession();
        
        try {
            User user = new User(13,"李四","567");
            
            session.getMapper(UserMapper.class).update(user);
            
            //事务提交
            session.commit();
            
            session.close();
        } catch (Exception e) {
            e.printStackTrace();
            session.rollback();
        }
        
    }
    //测试注解删除方法
    @Test
    public void delete(){
        
        //得到sqlSession
        SqlSession session = MyBatiesUtil.getSqlSession();
        
        try {
            
            session.getMapper(UserMapper.class).delete(14);
            
            //事务提交
            session.commit();
            
            session.close();
        } catch (Exception e) {
            e.printStackTrace();
            session.rollback();
        }
        
    }
    //测试注解查询集合方法
    @Test
    public void list(){
        
        //得到sqlSession
        SqlSession session = MyBatiesUtil.getSqlSession();
        List<User> list = null;
        try {
            
            list = session.getMapper(UserMapper.class).list();
            
            System.out.println(list);
            //事务提交
            session.commit();
            
            session.close();
        } catch (Exception e) {
            e.printStackTrace();
            session.rollback();
        }
        
    }
    //测试注解查询单个方法
    @Test
    public void load(){
        
        //得到sqlSession
        SqlSession session = MyBatiesUtil.getSqlSession();
        try {
            
            User user = session.getMapper(UserMapper.class).load(13);
            
            System.out.println(user);
            //事务提交
            session.commit();
            
            session.close();
        } catch (Exception e) {
            e.printStackTrace();
            session.rollback();
        }
        
    }
}

对Mybatis的初步认识的更多相关文章

  1. java 持久框架mybatis的初步学习

    什么是 MyBatis? MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架.MyBatis 消除 了几乎所有的 JDBC 代码和参数的手工设置以及结果集的检索.MyBati ...

  2. Mybatis的初步使用

    MyBatis 是当下最流行的持久层框架,也是ORM框架,本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google ...

  3. Mybatis学习-初步认知与使用

    Mybatis是一款优秀的持久层框架.且支持定制化SQL,存储过程以及高级映射 Mybatis几乎免除了所有的JDBC代码以及设置参数和获取结果集的工作,它使用简单的XML或注解来配置原始类型.接口和 ...

  4. (一)Mybatis之初步接触

    Maven的安装及环境配置 安装及配置只需按照以下三个链接的步骤走 撸帝的博客https://www.funtl.com/zh/maven/Maven-%E5%AE%89%E8%A3%85%E9%85 ...

  5. 初识 tk.mybatis.mapper

    在博客园发表Mybatis Dynamic Query后,一位园友问我知不知道通用mapper,仔细去找了一下,还真的有啊,比较好的就是abel533写的tk.mybatis.mapper. 本次例子 ...

  6. 初识 tk.mybatis.mapper 通用mapper

    在博客园发表Mybatis Dynamic Query后,一位园友问我知不知道通用mapper,仔细去找了一下,还真的有啊,比较好的就是abel533写的tk.mybatis.mapper. 本次例子 ...

  7. mybatis源码-解析配置文件(二)之解析的流程

    目录 1. 简介 2. 配置文件解析流程分析 2.1 调用 2.2 解析的目的 2.3 XML 解析流程 2.3.1 build(parser) 2.3.2 new XMLConfigBuilder( ...

  8. mybatis源码-解析配置文件(一)之XML的DOM解析方式

    目录 简介 Java 中 XML 文件解析 解析方式 DOM 解析 XML 新建 XML 文件 DOM 操作相关类 Java 读取 XML 文件 一起学 mybatis @ 简介 在之前的文章< ...

  9. SSM初步整合一

    SSM(spring+springmvc+mybatis)初步整合一配置步骤: 步骤一.导入所需jar包 步骤二 .配置web.xml文件 <?xml version="1.0&quo ...

随机推荐

  1. 【redis基础】

    基础知识 http://www.runoob.com/redis/redis-partitioning.html redis性能分析 https://www.cnblogs.com/mushroom/ ...

  2. jquery之链式调用,层级菜单

    一. 链式调用的含义 jquery对象的方法会在执行完后返回这个jquery对象,所有jquery对象的方法可以连起来写: $('#div1') // id为div1的元素 .children('ul ...

  3. centos7 systemd 必知必会

    systemd 简介: systemd 是一个 Linux 系统基础组件的集合, 提供了一个系统和服务管理器, 运行为 PID 1 并负责启动其它程序 功能包括: 1.支持并行化任务 2.同时采用 s ...

  4. 玩转MongoDB

    一.主从复制 1)首先主从服务器在启动的时候,分别要设置master.slave选项,对于slave可以启动中设置源,也可以在启动后设置源. 如:主:mongod --dbpath=/data/mon ...

  5. HTML-★★★格式与布局fixed/absolute/relative/z-index/float★★★

    很多网页都存在一个悬浮的操作条或者广告区,无论如何上下滚动网页,操作条或广告区都不会动,这个就是div制作,位置锁定在屏幕指定位置,现在我们就学习下网页的格式与布局. position 位置,来给di ...

  6. Go语言fmt包详解

    格式化输出函数 fmt包含有格式化I/O函数,类似于C语言的printf和scanf.格式字符串的规则来源于C,但更简单一些 1.print和println方法 print输出给定的字符串,如果是数值 ...

  7. 限制USB延迟启动

    阻止用户从未经授权的位置安装设备驱动程序. 组策略 ...too long too see directly. what determins when a drivers i s  load. spe ...

  8. APP的功能分类及打包与发布的分类方式

    智能手机的出现改变了我们的生活,同时各种各样的APP充斥在我们的手机当中.那么我先现在在来熟悉一下APP的分类及其用途:工具类.社交类.信息类.娱乐类.生活类等几大类.我么了解了APP的用途分类,那么 ...

  9. Hibernate的抓取策略(优化)

    延迟加载的概述 什么是延迟加载 延迟加载:lazy(懒加载).执行到该行代码的时候,不会发送语句去进行查询,在真正使用这个对象的属性的时候才会发送SQL语句进行查询. 延迟加载的分类 l  类级别的延 ...

  10. 关于 vertical-align 的一些小知识

    引子 在日常开发过程中,我们经常会遇到如下的场景,一行中既有图片也有文字,而且图片还要和文字对齐.效果如下: 通常代码如下: <!DOCTYPE html> <html> &l ...