• Mybatis(四)


    9. MyBatis的逆向工程

    正向工程:先创建Java实体类,由框架负责根据实体类生成数据库表。Hibernate是支持正向工程的

    逆向工程:先创建数据库表,由框架负责根据数据库表,反向生成如下资源:

    • Java实体类

    • Mapper接口

    • Mapper映射文件

    在这里插入图片描述

    9.1 创建逆向工程的步骤

    9.1.1 添加依赖和插件

    
    <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.0modelVersion>
    
        <groupId>com.atguigu.mybatisgroupId>
        <artifactId>MyBatis_MBGartifactId>
        <version>1.0-SNAPSHOTversion>
        <packaging>jarpackaging>
    
        
        <dependencies>
            <dependency>
                <groupId>org.mybatisgroupId>
                <artifactId>mybatisartifactId>
                <version>3.5.7version>
            dependency>
            
            <dependency>
                <groupId>junitgroupId>
                <artifactId>junitartifactId>
                <version>4.12version>
                <scope>testscope>
            dependency>
    
            
            <dependency>
                <groupId>mysqlgroupId>
                <artifactId>mysql-connector-javaartifactId>
                <version>5.1.3version>
            dependency>
    
            
            <dependency>
                <groupId>log4jgroupId>
                <artifactId>log4jartifactId>
                <version>1.2.17version>
            dependency>
        dependencies>
    
        
        <build>
    
            
            <plugins>
    
                
                <plugin>
                    <groupId>org.mybatis.generatorgroupId>
                    <artifactId>mybatis-generator-maven-pluginartifactId>
                    <version>1.3.0version>
    
                    
                    <dependencies>
    
                        
                        <dependency>
                            <groupId>org.mybatis.generatorgroupId>
                            <artifactId>mybatis-generator-coreartifactId>
                            <version>1.3.2version>
                        dependency>
    
                        
                        <dependency>
                            <groupId>com.mchangegroupId>
                            <artifactId>c3p0artifactId>
                            <version>0.9.2version>
                        dependency>
    
                        
                        <dependency>
                            <groupId>mysqlgroupId>
                            <artifactId>mysql-connector-javaartifactId>
                            <version>5.1.8version>
                        dependency>
                    dependencies>
                plugin>
            plugins>
        build>
    
    
    project>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83

    9.1.2 创建MyBatis的核心配置文件

    
    DOCTYPE configuration
            PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
            "http://mybatis.org/dtd/mybatis-3-config.dtd">
    <configuration>
    
        <properties resource="jdbc.properties"/>
    
        <typeAliases>
            <package name="com.atguigu.mybatis.pojo"/>
        typeAliases>
    
        <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>
    
        <mappers>
            <package name="com.atguigu.mybatis.mapper"/>
        mappers>
    configuration>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28

    9.1.3 创建逆向工程的配置文件

    文件名必须是:generatorConfig.xml

    
    DOCTYPE generatorConfiguration
            PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
            "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
    <generatorConfiguration>
        
        <context id="DB2Tables" targetRuntime="MyBatis3Simple">
            
            
            <jdbcConnection driverClass="com.mysql.cj.jdbc.Driver"
                            connectionURL="jdbc:mysql://localhost:3306/mybatis"
                            userId="root"
                            password="123456">
            jdbcConnection>
            
            
            <javaModelGenerator targetPackage="com.atguigu.mybatis.pojo" targetProject=".\src\main\java">
                <property name="enableSubPackages" value="true" />
                <property name="trimStrings" value="true" />
            javaModelGenerator>
            
            
            <sqlMapGenerator targetPackage="com.atguigu.mybatis.mapper"
                             targetProject=".\src\main\resources">
                <property name="enableSubPackages" value="true" />
            sqlMapGenerator>
            
            
            <javaClientGenerator type="XMLMAPPER"
                                 targetPackage="com.atguigu.mybatis.mapper" targetProject=".\src\main\java">
                <property name="enableSubPackages" value="true" />
            javaClientGenerator>
            
            
            
            
            <table tableName="t_emp" domainObjectName="Emp"/>
            <table tableName="t_dept" domainObjectName="Dept"/>
        context>
    generatorConfiguration>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44

    9.1.4 执行MBG插件的generate目标

    在这里插入图片描述

    • 如果出现报错:Exception getting JDBC Driver,可能是pom.xml中,数据库驱动配置错误

    • dependency中的驱动在这里插入图片描述

      • mybatis-generator-maven-plugin插件中的驱动

      • 在这里插入图片描述

      • 两者的驱动版本应该相同

    • 执行结果
      在这里插入图片描述

    9.2 QBC查询

    9.2.1 查询

    • selectByExample:按条件查询,需要传入一个example对象或者null;如果传入一个null,则表示没有条件,也就是查询所有数据
    • example.createCriteria().xxx:创建条件对象,通过andXXX方法为SQL添加查询添加,每个条件之间是and关系
    • example.or().xxx:将之前添加的条件通过or拼接其他条件
      在这里插入图片描述
    @Test public void testMBG() throws IOException {
    	InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
    	SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
    	SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
    	SqlSession sqlSession = sqlSessionFactory.openSession(true);
    	EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);
    	EmpExample example = new EmpExample();
    	//名字为张三,且年龄大于等于20
    	example.createCriteria().andEmpNameEqualTo("张三").andAgeGreaterThanOrEqualTo(20);
    	//或者did不为空
    	example.or().andDidIsNotNull();
    	List<Emp> emps = mapper.selectByExample(example);
    	emps.forEach(System.out::println);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    在这里插入图片描述

    9.2.2 增改

    • updateByPrimaryKey:通过主键进行数据修改,如果某一个值为null,也会将对应的字段改为null

    • mapper.updateByPrimaryKey(new Emp(1,"admin",22,null,"456@qq.com",3));

      • 在这里插入图片描述
    • updateByPrimaryKeySelective():通过主键进行选择性数据修改,如果某个值为null,则不修改这个字段

    • mapper.updateByPrimaryKeySelective(new Emp(2,"admin2",22,null,"456@qq.com",3));

      • 在这里插入图片描述

    10. 分页插件

    10.1 配置

    10.1.1 添加依赖

    pom.xml

    
    <dependency>
    	<groupId>com.github.pagehelpergroupId>
    	<artifactId>pagehelperartifactId>
    	<version>5.2.0version>
    dependency>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    10.1.2 配置分页插件

    mybatis-config.xml中配置插件

    在这里插入图片描述

    <plugins>
    	
    	<plugin interceptor="com.github.pagehelper.PageInterceptor">plugin>
    plugins>
    
    • 1
    • 2
    • 3
    • 4

    10.2 使用

    10.2.1 开启分页功能

    在查询功能之前使用PageHelper.startPage(int pageNum, int pageSize)开启分页功能

    • pageNum:当前页的页码
    • pageSize:每页显示的条数
    @Test
    public void testPageHelper() throws IOException {
    	InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
    	SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
    	SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
    	SqlSession sqlSession = sqlSessionFactory.openSession(true);
    	EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);
    	
        //访问第一页,每页四条数据
    	PageHelper.startPage(1,4);
    	List<Emp> emps = mapper.selectByExample(null);
    	emps.forEach(System.out::println);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    在这里插入图片描述

    10.3 分页相关数据

    方法一:直接输出
    @Test
    public void testPageHelper() throws IOException {
    	InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
    	SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
    	SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
    	SqlSession sqlSession = sqlSessionFactory.openSession(true);
    	EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);
    	
        //访问第一页,每页四条数据
    	Page<Object> page = PageHelper.startPage(1, 4);
    	List<Emp> emps = mapper.selectByExample(null);
    	
        //在查询到List集合后,打印分页数据
    	System.out.println(page);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    分页相关数据:

    Page{count=true, pageNum=1, pageSize=4, startRow=0, endRow=4, total=8, pages=2, reasonable=false, pageSizeZero=false}[Emp{eid=1, empName='admin', age=22, sex='男', email='456@qq.com', did=3}, Emp{eid=2, empName='admin2', age=22, sex='男', email='456@qq.com', did=3}, Emp{eid=3, empName='王五', age=12, sex='女', email='123@qq.com', did=3}, Emp{eid=4, empName='赵六', age=32, sex='男', email='123@qq.com', did=1}]
    
    • 1
    方法二:使用PageInfo

    在查询获取list集合之后,使用PageInfo pageInfo = new PageInfo<>(List list, intnavigatePages)获取分页相关数据

    • list:分页之后的数据
    • navigatePages:导航分页的页码数
    @Test
    public void testPageHelper() throws IOException {
    	InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
    	SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
    	SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
    	SqlSession sqlSession = sqlSessionFactory.openSession(true);
    	
        EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);
    	
        PageHelper.startPage(1, 4);
    	List<Emp> emps = mapper.selectByExample(null);
    	
        PageInfo<Emp> page = new PageInfo<>(emps,5);
    	System.out.println(page);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    分页相关数据:

    PageInfo{
    pageNum=1, pageSize=4, size=4, startRow=1, endRow=4, total=8, pages=2, 
    list=Page{count=true, pageNum=1, pageSize=4, startRow=0, endRow=4, total=8, pages=2, reasonable=false, pageSizeZero=false}[Emp{eid=1, empName='admin', age=22, sex='男', email='456@qq.com', did=3}, Emp{eid=2, empName='admin2', age=22, sex='男', email='456@qq.com', did=3}, Emp{eid=3, empName='王五', age=12, sex='女', email='123@qq.com', did=3}, Emp{eid=4, empName='赵六', age=32, sex='男', email='123@qq.com', did=1}], 
    prePage=0, nextPage=2, isFirstPage=true, isLastPage=false, hasPreviousPage=false, hasNextPage=true, navigatePages=5, navigateFirstPage=1, navigateLastPage=2, navigatepageNums=[1, 2]}
    
    • 1
    • 2
    • 3
    • 4

    其中list中的数据等同于方法一中直接输出的page数据

    常用数据:
    • pageNum:当前页的页码
    • pageSize:每页显示的条数
    • size:当前页显示的真实条数
    • total:总记录数
    • pages:总页数
    • prePage:上一页的页码
    • nextPage:下一页的页码
    • isFirstPage/isLastPage:是否为第一页/最后一页
    • hasPreviousPage/hasNextPage:是否存在上一页/下一页
    • navigatePages:导航分页的页码数
    • navigatepageNums:导航分页的页码,[1,2,3,4,5]
  • 相关阅读:
    CentOS7安装xvfb,解决服务器没有X-Server的问题
    Kafka3.0.0版本——消费者(消费者组原理)
    Golang 基础面试题 01
    动作活体检测能力,构建安全可靠的支付级“刷脸”体验
    使用 Docker Compose 快速搭建监控网站 uptime-kuma
    C++:C++编程语言学习之逻辑控制语句(循环语句&判断语句)&异常处理(try-catch-throw)的简介、案例应用之详细攻略
    AWS S3
    Linux抓包工具tcpdump
    ros2与turtlebot3仿真教程-turtlebot3导航
    EOS密钥被盗后如何恢复?
  • 原文地址:https://blog.csdn.net/qq_39236499/article/details/134334501