zoukankan      html  css  js  c++  java
  • 一步一步教你用IntelliJ IDEA 搭建SSM框架(2)——配置mybatis-geneator

    我们要搭建整个SSM框架,所以要继续上篇文章没有完成的工作,下面配置mybatis-geneator,自动生成mybatis代码。

    在上篇文章中的pom.xml的配置文件中已经加了mybatis-geneator的依赖包,如下图:

    请注意:上图的plugins是和pluginManagement是同级的,如果把mybatis.geneator的plugin放在pluginManagement就引用不到mybatis-geneator

    然后在 applicationContext.xml文件中添加下面代码:

    <!-- 配置会话工厂SqlSessionFactory -->
    
        <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
            <!-- 数据源 -->
            <property name="dataSource" ref="dataSource"/>
            <property name="mapperLocations" value="classpath:sqlmap/*Mapper.xml"/>
            <property name="typeAliasesPackage" value="cn.only.entity" />
    
        </bean>
    
        <!-- 在spring容器中配置mapper的扫描器产生的动态代理对象在spring的容器中自动注册,bean的id就是mapper类名(首字母小写)-->
        <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
            <!-- 指定扫描包的路径,就是mapper接口的路径,多个包中间以 半角逗号隔开   -->
            <property name="basePackage" value="cn.only.dao"/>
            <!-- 配置sqlSessionFactoryBeanName -->
            <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
        </bean>
    View Code

     generatorConfig.xml的配置如下:

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE generatorConfiguration PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
            "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
    <generatorConfiguration>
        <!--导入属性配置 -->
        <properties resource="generator.properties"/>
    
        <classPathEntry
                location="C:UsersAdministrator.m2
    epositorymysqlmysql-connector-java5.0.8mysql-connector-java-5.0.8.jar" />
        <context id="context1">
            <!-- 注释 -->
            <commentGenerator>
                <property name="suppressAllComments" value="true" /><!-- 是否取消注释 -->
                <property name="suppressDate" value="true" /> <!-- 是否生成注释代时间戳 -->
            </commentGenerator>
    
            <jdbcConnection driverClass="${driver}"
                            connectionURL="${url}"
                            userId="${username}"
                            password="${password}" />
    
            <!-- 类型转换 -->
            <javaTypeResolver>
                <!-- 是否使用bigDecimal, false可自动转化以下类型(Long, Integer, Short, etc.) -->
                <property name="forceBigDecimals" value="false" />
            </javaTypeResolver>
    
            <javaModelGenerator targetPackage="${modelPackage}"
                                targetProject="${modelProject}" />
            <sqlMapGenerator targetPackage="${sqlPackage}" targetProject="${sqlProject}" />
            <javaClientGenerator targetPackage="${mapperPackage}"
                                 targetProject="${mapperProject}" type="XMLMAPPER" />
    
            <!-- 如果需要通配所有表 直接用sql的通配符    %即可 -->
            <table schema="" tableName="${table}" enableCountByExample="false"
                   enableUpdateByExample="false" enableDeleteByExample="false"
                   enableSelectByExample="false" selectByExampleQueryId="false"/>
    
        </context>
    </generatorConfiguration>
    View Code

    代码中的classPathEntry的location换成您本地的。如下图,

    注意:如果mysql-connector-java的版本与本地的MySQL版本不配套,数据库操作会报错。

     generator.properties配置

    driver=com.mysql.jdbc.Driver
    url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&serverTimezone=UTC
    username=root
    password=******
    
    #entity 包名和 java目录
    modelPackage=cn.only.entity
    modelProject=src/main/java
    #sqlmap包名 和resources目录
    sqlPackage=sqlmap
    sqlProject=src/main/resources
    #mapper包名和 java目录
    mapperPackage=cn.only.dao
    mapperProject=src/main/java
    
    table=message
    View Code

    注意:上面的代码中如果没有serverTimezone=UTC,代码运行会报错

    modelPackage:连接数据库自动生成的实体类保存的位置

    sqlPackage:生成xml映射文件保存的位置

    mapperPackage:生成数据库接口保存的位置

    table:数据库里面表的名字

    现在mybatis-geneator已经配置好了。

    MySQL数据库中已经建立了数据库test和表message。

    点击IntelliJ IDEA右侧边栏的Maven Projects,如下图。

    双击上图中的 mybatis-generator:generate,运行结果如下图

    mybatis-generator运行成功以后会自动生成以下文件:

     

     现在Spring MVC + Spring + MyBatis 的框架已经搭建好,下面就用junit测试工具,测一下数据能不能正常写入数据库。

    打开MessageMapper文件,添加@Repository标签,表明这是数据访问组件,如下图

    上图中鼠标放在紧跟在MessageMapper后面,按alt+enter,选择Create Test,弹窗如下图:

    上图中选中insert,点击OK,会在test目录下生成MessageMapperTest测试文件,测试代码就写在此文件中如下:

    package cn.only.dao;
    
    import cn.only.entity.Message;
    import org.junit.After;
    import org.junit.Before;
    import org.junit.Test;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.context.ApplicationContext;
    import org.springframework.context.support.ClassPathXmlApplicationContext;
    
    import static org.junit.Assert.*;
    
    public class MessageMapperTest {
        private ApplicationContext applicationContext;
    
        @Autowired
        private MessageMapper mapper;
        @Before
        public void setUp() throws Exception {
            // 加载spring配置文件
            applicationContext = new ClassPathXmlApplicationContext("classpath:spring/applicationContext.xml");
            // 导入需要测试的
            mapper = applicationContext.getBean(MessageMapper.class);
        }
    
        @After
        public void tearDown() throws Exception {
        }
    
        @Test
        public void insert() throws Exception{
            Message message = new Message();
            message.setCommand("做仙女");
            message.setContent("吃美食");
            message.setDescription("云游四方");
            int result = mapper.insert(message);
            System.out.println(result);
            assert (result == 1);
        }
    }
    View Code

    如上图点击绿色圆圈和三角形组合,点击Run ‘insert()’,运行结果如下,表示运行成功。

     

    打开数据库查看结果如下:

    好了,SSM框架已经搭建成功。

    本文参照这篇文章写的:https://www.cnblogs.com/toutou/p/9015126.html#_nav_0

  • 相关阅读:
    时间复杂度 空间复杂度
    qt 打开串口 UI卡死
    python 网络编程
    Java 理解泛型的基本含义
    Java LinkedList 和 ArrayList
    Java renameTo()重新命名此抽象路径名表示的文件
    Java separatorChar 如何在Java里面添加
    Java 遍历文件夹里面的全部文件、指定文件
    Java File文件操作 创建文件目录,删除文件目录
    Java toString()方法的神奇之处
  • 原文地址:https://www.cnblogs.com/greenteaone/p/11083172.html
Copyright © 2011-2022 走看看