栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

学习博客:【MyBatis】初识MyBatis

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

学习博客:【MyBatis】初识MyBatis

环境:

  • JDK 1.8
  • MySQL 8.0.28
  • maven 3.8.5
  • IDEA

基础:

  • JDBC
  • MySQL
  • Java
  • Maven
  • Junit

框架:配置文件 官网文档

1. 简介 1.1 什么是MyBatis
  • 持久层框架
  • 定制化SQL、存储过程、高级映射
  • 避免JDBC、手动设置参数、获取结果集
  • XML、注解配置映射原生类型、接口、POJO为数据库中的记录
  • apache的开源项目iBatis(internet + abatis)基于Java 2010年由apache software foundation迁移到了google code 改名为MyBatis
  • 2013.11 迁移到github
  • iBatis提供的持久层框架包括SQL Maps 和 Data Access Objects(DAOs)

获取:

  • maven:

    
    
        org.mybatis
        mybatis
        3.5.9
    
    
  • Github:https://github.com/mybatis/mybatis-3/releases

  • 中文文档:https://mybatis.org/mybatis-3/zh/getting-started.html

1.2 持久化
  • 数据持久化:将程序中的数据在持久状态和瞬时状态转化的过程
  • 内存:断电即失
  • 数据库(JDBC)、IO文件持久化

持久化的意义:

  • 有些对象不能丢失
  • 内存价格高
1.3 持久层

Dao Service Controller

  • 完成持久化工作的代码块
  • 层 界限明显
1.4 MyBatis优势

  • 将数据存入数据库中
  • 方便、灵活
  • 简化JDBC 框架
  • 可替代,但更容易上手
  • sql与代码分离
  • 提供映射标签、支持对象和数据库的orm字段关系映射
  • 提供对象关系映射标签,支持对象关系组建维护
  • 提供xml标签,可编写动态SQL
2. 第一个MyBatis程序 2.1 搭建环境
  1. 搭建数据库

    CREATE DATABASE `mybatis`;
    
    USE mybatis
    
    CREATE TABLE `user`(
        `id` INT(20) NOT NULL,
        `name` VARCHAr(30) DEFAULT NULL,
        `pwd` VARCHAr(30) DEFAULT NULL,
        PRIMARY KEY(`id`)`mybatis``user`
    )ENGINE=INNODB DEFAULT CHARSET=utf8;
    
    INSERT INTO `user`(`id`,`name`,`pwd`)VALUES
    (1,'李倪','111111'),
    (2,'王记','313131'),
    (3,'赵新','121212');
    
  2. 新建普通maven项目

  3. 删除src目录

  4. 导入maven依赖

    
    
        4.0.0
    
        
        com.yl
        MyBatis-Study
        1.0-SNAPSHOT
    
        
        
            
            
                mysql
                mysql-connector-java
                8.0.27
            
    
            
            
            
                org.mybatis
                mybatis
                3.5.9
            
    
            
            
                junit
                junit
                4.12
                test
            
        
    
    
    
    
2.2 创建模块
  • mybatis核心配置文件

    
    
    
    
    
        
            
                
                
                    
                    
                    
                    
                
            
        
    
    
    
  • mybatis工具类

    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 java.io.IOException;
    import java.io.InputStream;
    
    //sqlSessionFactory --> sqlSession
    public class MyBatisUntils {
    
        private static SqlSessionFactory sqlSessionFactory;
    
        //加载资源
        static{
            try {
                //获取sqlSessionFactory对象
                String resource = "org/mybatis/example/mybatis-config.xml";
                InputStream inputStream = Resources.getResourceAsStream(resource);
                sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        
        //创建执行SQL的对象
        public static SqlSession getSqlSession(){
            return sqlSessionFactory.openSession();
        }
        
    }
    
2.3 编写代码
  • 实体类

    package com.yl.pojo;
    
    
    //实体类
    public class User {
        private int id;
        private String name;
        private String pwd;
    
        public User() {
        }
    
        public User(int id, String name, String pwd) {
            this.id = id;
            this.name = name;
            this.pwd = pwd;
        }
    
        public int getId() {
            return id;
        }
    
        public void setId(int id) {
            this.id = id;
        }
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public String getPwd() {
            return pwd;
        }
    
        public void setPwd(String pwd) {
            this.pwd = pwd;
        }
    
        @Override
        public String toString() {
            return "User{" +
                    "id=" + id +
                    ", name='" + name + ''' +
                    ", pwd='" + pwd + ''' +
                    '}';
        }
    }
    
  • DaoMapper接口

    import com.yl.pojo.User;
    import java.util.List;
    
    public interface UserMapper {
        List getUserList();
    }
    
    
  • 接口实现类由原来的UserDaoImpl转换为Mapper配置文件

    
    
    
    
        
        
        
    
    
2.4 测试
  • junit测试

    • @Test
      public void test(){
      
          //获取SqlSession对象
          SqlSession sqlSession = MyBatisUntils.getSqlSession();
      
          //执行SQL getMapper
          UserMapper mapper = sqlSession.getMapper(UserMapper.class);
          List userList = mapper.getUserList();
      
          for (User user : userList) {
              System.out.println(user);
          }
      
          //关闭sqlSession
          sqlSession.close();
      
      }
      
    • 报错 org.apache.ibatis.binding.BindingException: Type interface com.yl.dao.UserMapper is not known to the MapperRegistry.

    • 在mybatis-config.xml下配置

          
          
              
          
      
    • 依然报错 java.lang.ExceptionInInitializerError

    • maven 约定大于配置 在pom.xml下配置

      
      
          
              
                  src/main/resources
                  
                      ***.xml
                  
                  true
              
              
                  src/main/java
                  
                      ***.xml
                  
                  false
              
          
      
      
    • 若依然报错 将xml的编码格式改为GBK

    常见问题:

    1. 配置文件未注册
    2. 绑定接口错误
    3. 方法名错误
    4. 返回类型错误
    5. Maven导出资源问题
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/888689.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号