美文网首页
idea根据表生成实体类和持久层

idea根据表生成实体类和持久层

作者: 龙眠散人 | 来源:发表于2021-05-12 14:44 被阅读0次

1、建立maven工程,选择骨架

接着一直next,然后finish

2、配置数据源

输入信息,测试连接

根据database生成实体类

生成dao层(持久层)代码 和实体类

a、配置pom.xml层

因为IntelliJ中没有mybatis-generato对应的插件,所以需要在MAVEN中使用 mybatis-generator-maven-plugin插件来完成功能。

<plugin>

        <groupId>org.mybatis.generator</groupId>

        <artifactId>mybatis-generator-maven-plugin</artifactId>

        <version>1.3.2</version>

        <dependencies>

          <dependency>

            <groupId>mysql</groupId>

            <artifactId>mysql-connector-java</artifactId>

            <version>5.1.34</version>

          </dependency>

        </dependencies>

        <configuration>

          <overwrite>true</overwrite>

        </configuration>

      </plugin>

b、 resources下建generatorConfig.xml,作为mybatis-generator-maven-plugin插件的执行目标。

<?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="jdbc.properties"/>  

    <!-- 指定数据连接驱动jar地址 -->  

    <classPathEntry location="C:\Users\Administrator\.m2\repository\mysql\mysql-connector-java\5.1.30\mysql-connector-java-5.1.30.jar" />  

    <!-- 一个数据库一个context -->  

    <context id="FCRMTables">  

        <!-- 注释 -->  

        <commentGenerator >  

            <property name="suppressAllComments" value="true"/><!-- 是否取消注释 -->  

            <property name="suppressDate" value="true" /> <!-- 是否生成注释代时间戳-->  

        </commentGenerator>  

        <!-- jdbc连接 -->  

        <jdbcConnection driverClass="${driverClassName}"  

            connectionURL="${url}" userId="${username}"  

            password="${password}" />  

        <!-- 类型转换 -->  

        <javaTypeResolver>  

            <!-- 是否使用bigDecimal, false可自动转化以下类型(Long, Integer, Short, etc.) -->  

            <property name="forceBigDecimals" value="false"/>  

        </javaTypeResolver>  

        <!-- 生成实体类的包名和位置 注意targetProject的值为实体类放在工程中具体位置的相对路径,-->  

        <javaModelGenerator targetPackage="com.qlm.entity"  

            targetProject="src/main/java" >  

            <!-- 是否在当前路径下新加一层schema,eg:fase路径com.oop.eksp.user.model, true:com.oop.eksp.user.model.[schemaName] -->  

            <property name="enableSubPackages" value="true"/>  

            <!-- 是否针对string类型的字段在set的时候进行trim调用 -->  

            <property name="trimStrings" value="true"/>  

        </javaModelGenerator>  

        <!-- 生成的SQLMapper映射文件包名和位置 -->  

        <sqlMapGenerator targetPackage="mybatisMapper"  

            targetProject="src/main/resources" >  

            <!-- 是否在当前路径下新加一层schema,eg:fase路径com.oop.eksp.user.model, true:com.oop.eksp.user.model.[schemaName] -->  

            <property name="enableSubPackages" value="true" />  

        </sqlMapGenerator>  

        <!-- 生成DAO的包名和位置,这里配置将生成的dao类放在me.gacl.dao这个包下 -->  

        <javaClientGenerator targetPackage="com.qlm.dao"  

            targetProject="src/main/java" type="XMLMAPPER" >  

            <!-- 是否在当前路径下新加一层schema,eg:fase路径com.oop.eksp.user.model, true:com.oop.eksp.user.model.[schemaName] -->  

            <property name="enableSubPackages" value="true" />  

        </javaClientGenerator>  

        <!-- 配置表信息 -->  

        <!-- schema即为数据库名 tableName为对应的数据库表 domainObjectName是要生成的实体类 enable*ByExample   

                是否生成 example类   -->    

        <!-- 更改tableName和domainObjectName就可以 -->  

        <table schema="qlm" tableName="tb_qlm_admin"  

            domainObjectName="Admin" enableCountByExample="false"  

            enableDeleteByExample="false" enableSelectByExample="false"  

            enableUpdateByExample="false">             

        </table>  

    </context>  

</generatorConfiguration>  

jdbc.properties文件如下

driverClassName=com.mysql.jdbc.Driver

url=jdbc:mysql://localhost:3306/***?autoReconnect=true&useUnicode=true&characterEncoding=utf-8

username=***

password=***

c、配置执行方式

新建maven执行,然后在右方表格中填入以下信息即可。 mybatis-generator:generate -e

点击run,则可生成持久化类和实体类

下面的测试时忘了改包名

可能遇到的问题

URI is not registered (Settings | Languages & Frameworks | Schemas and DTDs)

解决办法点击链接

URI is not registered (Settings | Languages & Frameworks | Schemas and DTDs)_别安;-CSDN博客

相关文章

网友评论

      本文标题:idea根据表生成实体类和持久层

      本文链接:https://www.haomeiwen.com/subject/oreadltx.html