• mybatis generator


    引入依赖 

      <dependency>
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-core</artifactId>
                <version>1.3.7</version>
            </dependency>

    配置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="db.properties"/>

    <!-- 加载数据库驱动 -->
    <classPathEntry location="${class_path}" />

    <!-- context:生成一组对象的环境
    id:必选,上下文id,用于在生成错误时提示
    defaultModelType:指定生成对象的样式
    1,conditional:类似hierarchical;
    2,flat:所有内容(主键,blob)等全部生成在一个对象中,推荐使用;
    3,hierarchical:主键生成一个XXKey对象(key class),Blob等单独生成一个对象,其他简单属性在一个对象中(record class)
    targetRuntime:
    1,MyBatis3:默认的值,生成基于MyBatis3.x以上版本的内容,包括XXXBySample;
    2,MyBatis3Simple:类似MyBatis3,只是不生成XXXBySample;
    -->
    <context id="context1" targetRuntime="MyBatis3" defaultModelType="flat">

    <!-- 生成的Java文件的编码 -->
    <property name="javaFileEncoding" value="UTF-8"/>


    <commentGenerator>
    <!-- 是否去除自动生成的注释 true:是 : false:否 -->
    <property name="suppressAllComments" value="false" />
    <!-- 阻止注释中包含时间戳 true:是 : false:否 -->
    <property name="suppressDate" value="true" />
    <!-- 注释是否包含数据库表的注释信息 true:是 : false:否 -->
    <property name="addRemarkComments" value="true" />
    </commentGenerator>
    <!--数据库连接的信息:驱动类、连接地址、用户名、密码 -->
    <jdbcConnection driverClass="${jdbc.driver}"
    connectionURL="${jdbc.url}" userId="${jdbc.username}" password="${jdbc.password}" />


    <!-- java模型创建器,是必须要的元素 负责:1,key类(见context的defaultModelType);2,java类;3,查询类
    targetPackage:生成的类要放的包,真实的包受enableSubPackages属性控制;
    targetProject:目标项目,指定一个存在的目录下,生成的内容会放到指定目录中,如果目录不存在,MBG不会自动建目录
    -->
    <javaModelGenerator targetPackage="cn.qin.entity" targetProject="src/main/java">
    <!-- 设置一个根对象,
    如果设置了这个根对象,那么生成的keyClass或者recordClass会继承这个类;在Table的rootClass属性中可以覆盖该选项
    注意:如果在key class或者record class中有root class相同的属性,MBG就不会重新生成这些属性了,包括:
    1,属性名相同,类型相同,有相同的getter/setter方法;
    -->
    <!--<property name="rootClass" value="com.enjoylearning.mybatis.entity.BaseEntity" />-->
    </javaModelGenerator>


    <!-- 生成SQL map的XML文件生成器,
    targetPackage:生成的类要放的包,真实的包受enableSubPackages属性控制;
    targetProject:目标项目,指定一个存在的目录下,生成的内容会放到指定目录中,如果目录不存在,MBG不会自动建目录
    -->
    <sqlMapGenerator targetPackage="." targetProject="src/main/resources/mapper">
    </sqlMapGenerator>


    <!-- 对于mybatis来说,即生成Mapper接口,注意,如果没有配置该元素,那么默认不会生成Mapper接口
    type:选择怎么生成mapper接口(在MyBatis3/MyBatis3Simple下):
    1,ANNOTATEDMAPPER:会生成使用Mapper接口+Annotation的方式创建(SQL生成在annotation中),不会生成对应的XML;
    2,MIXEDMAPPER:使用混合配置,会生成Mapper接口,并适当添加合适的Annotation,但是XML会生成在XML中;
    3,XMLMAPPER:会生成Mapper接口,接口完全依赖XML;
    注意,如果context是MyBatis3Simple:只支持ANNOTATEDMAPPER和XMLMAPPER
    -->
    <javaClientGenerator targetPackage="cn.qin.mapper" targetProject="src/main/java" type="XMLMAPPER" />




    <!-- shema 数据库 tableName表明 -->
    <table schema="${jdbc.username}" tableName="user_item" enableCountByExample="false"
    enableUpdateByExample="false" enableDeleteByExample="false"
    enableSelectByExample="false" selectByExampleQueryId="false">
    <generatedKey column="id" sqlStatement="MySql"/>
    </table>


    </context>
    </generatorConfiguration>

    db.properties

    jdbc.driver=com.mysql.cj.jdbc.Driver
    jdbc.url=jdbc:mysql://localhost:3306/test1?serverTimezone=UTC
    jdbc.username=root
    jdbc.password=123123
    
    class_path=C:/Users/Administrator/.m2/repository/mysql/mysql-connector-java/8.0.17/mysql-connector-java-8.0.17.jar
    project_src=src/main/java
    project_mapper_xml=src/main/resources/mapper

    执行mvn 

    mybatis-generator:generate
  • 相关阅读:
    ASP.NET的三层架构(DAL,BLL,UI)
    页面开发辅助类—HtmlHelper初步了解
    ASP MVC之参数传递
    ASP.NET MVC学习之母版页和自定义控件的使用
    ASP.Net MVC开发基础学习笔记(2):HtmlHelper与扩展方法
    UITableView动态改变Cell高度
    UITableView动态改变Cell高度
    nodejs豆瓣爬虫
    nodejs豆瓣爬虫
    苹果系统OSX中Automator批量重命名
  • 原文地址:https://www.cnblogs.com/qin1993/p/11943867.html
Copyright © 2020-2023  润新知