关于Mybatis-generator中,<properties> resource jdbc.properties does not exist 的问题

本文详细解析MyBatis Generator的配置文件generatorConfig.xml及jdbc.properties的正确设置,特别是资源路径配置的问题,确保生成的实体类、Mapper文件及DAO接口符合项目需求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题:

  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="jdbc.properties"></properties>
 
    <!-- 指定数据库驱动的jdbc驱动jar包的位置 -->
    <classPathEntry location="mysql-connector-java-5.1.47.jar" />
 
    <!-- context 是逆向工程的主要配置信息 -->
    <!-- id:名字 -->
    <!-- targetRuntime:设置生成的文件适用于 mybatis 版本 -->
    <context id="default" targetRuntime="MyBatis3">
 
        <!--optional,旨在创建class时,对注释进行控制-->
        <commentGenerator>
            <property name="suppressDate" value="true" />
            <!-- 是否去除自动生成的注释 true:是 : false:否 -->
            <property name="suppressAllComments" value="true" />
        </commentGenerator>
 
        <!--jdbc的数据库连接-->
        <jdbcConnection driverClass="${spring.datasource.driver-class-name}"
                        connectionURL="${spring.datasource.url}"
                        userId="${spring.datasource.username}"
                        password="${spring.datasource.password}">
        </jdbcConnection>
 
        <!--非必须,类型处理器,在数据库类型和java类型之间的转换控制-->
        <javaTypeResolver>
            <!-- 默认情况下数据库中的 decimal,bigInt 在 Java 对应是 sql 下的 BigDecimal 类 -->
            <!-- 不是 double 和 long 类型 -->
            <!-- 使用常用的基本类型代替 sql 包下的引用类型 -->
            <property name="forceBigDecimals" value="false" />
        </javaTypeResolver>
 
        <!-- targetPackage:生成的实体类所在的包 -->
        <!-- targetProject:生成的实体类所在的硬盘位置 -->
        <javaModelGenerator targetPackage="com.is.pojo"
                            targetProject=".\src\main\java">
            <!-- 是否允许子包 -->
            <property name="enableSubPackages" value="false" />
            <!-- 是否对modal添加构造函数 -->
            <property name="constructorBased" value="true" />
            <!-- 是否清理从数据库中查询出的字符串左右两边的空白字符 -->
            <property name="trimStrings" value="true" />
            <!-- 建立modal对象是否不可改变 即生成的modal对象不会有setter方法,只有构造方法 -->
            <property name="immutable" value="false" />
        </javaModelGenerator>
 
        <!-- targetPackage 和 targetProject:生成的 mapper 文件的包和位置 -->
        <sqlMapGenerator targetPackage="mappers"
                         targetProject=".\src\main\resource\mybatis\common">
            <!-- 针对数据库的一个配置,是否把 schema 作为字包名 -->
            <property name="enableSubPackages" value="false" />
        </sqlMapGenerator>
 
        <!-- targetPackage 和 targetProject:生成的 interface 文件的包和位置 -->
        <javaClientGenerator type="XMLMAPPER"
                             targetPackage="com.is.dao" targetProject=".\src\main\java">
            <!-- 针对 oracle 数据库的一个配置,是否把 schema 作为字包名 -->
            <property name="enableSubPackages" value="false" />
        </javaClientGenerator>
        <table tableName="user" domainObjectName="User"
               enableCountByExample="false" enableUpdateByExample="false"
               enableDeleteByExample="false" enableSelectByExample="false"
               selectByExampleQueryId="false">
        </table>
    </context>
</generatorConfiguration>

  jdbc.properties

spring.datasource.driverLocation=mysql-connector-java-5.1.47.jar
spring.datasource.driverClassName=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/is_db?characterEncoding=utf-8
spring.datasource.username=root
spring.datasource.password=123456

在使用Mybatis-generator中,配置文件时,出现问题

MyBatis Generator Started...
  Buildfile: E:\Workspace\sts-workspace\.metadata\.plugins\org.mybatis.generator.eclipse.ui\.generatedAntScripts\LeafageUnifiedDevelopmentPlatform-generatorConfig.xml.xml
  11:14:53.494 [Worker-18: Launching LeafageUnifiedDevelopmentPlatform-generatorConfig.xml] DEBUG org.mybatis.generator.eclipse.ui.ant.logging.AntLogFactory - Logging initialized using 'org.mybatis.generator.eclipse.ui.ant.logging.slf4j.Slf4jLoggingLogFactory@49a26000' adapter.
  11:14:53.509 [Worker-18: Launching LeafageUnifiedDevelopmentPlatform-generatorConfig.xml] DEBUG org.mybatis.generator.logging.LogFactory - Logging initialized using 'org.mybatis.generator.eclipse.ui.ant.logging.AntLogFactory@14794f6e' adapter.
  <properties> resource jdbc.properties does not exist
MyBatis Generator Finished

解决:

  不是像网上查到的加classpath,修改

<!--导入属性配置-->
    <properties resource="jdbc.properties"></properties>

<!--导入属性配置-->
    <properties resource="config/jdbc.properties"></properties>

文件目录展示如下

原因:

properties会去src/main/resourses目录下寻找,而我们经常将目录再添加一层conf或者config,就要修改指向conf或者config目录。

评论回复说明:首先,使用mybatis generator弄清楚,有2个文件一个是 mybatisGenerator.xml,这个是用来运行的;还有个是jdbc.properties文件,这个是jdbc的配置文件(可以写在mybatisGenerator.xml里,但是为了可迁移性,就把独立出来了)。

目前问题主要出现在,mybatisGenerator.xml寻找jdbc.properties文件,找不到。部分原因在于,有的教程是resource文件夹下,直接写jdbc.properties,有的教程会写在resource/config目录下,只要弄清这点就没有问题了。

MyBatis Generator插件在Maven项目中的配置需要通过Maven的`pom.xml`文件进行声明,而具体的生成配置则通过一个独立的XML文件(通常是`generatorConfig.xml`)来定义。以下是详细的说明: 1. **插件声明位置**: MyBatis Generator插件应该在Maven项目的`pom.xml`文件中进行声明,作为`<plugin>`配置的一部分。这确保了插件在构建过程中能够被正确加载和执行。插件的声明通常包含在`<build>`标签下的`<plugins>`部分中。例如: ```xml <build> <plugins> <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.4.1</version> <configuration> <configurationFile>${basedir}/src/main/resources/generatorConfig.xml</configurationFile> </configuration> </plugin> </plugins> </build> ``` 2. **插件配置文件位置**: MyBatis Generator插件的详细配置(如数据库连接信息、生成目标等)应该放在一个独立的XML文件中,通常是`src/main/resources/generatorConfig.xml`。这个文件包含了生成MyBatis代码所需的配置信息,例如数据库连接参数、表名映射规则以及生成的文件路径等[^1]。 一个基本的`generatorConfig.xml`文件内容可能如下: ```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> <context id="DB2Tables" targetRuntime="MyBatis3"> <jdbcConnection driverClass="oracle.jdbc.driver.OracleDriver" connectionURL="jdbc:oracle:thin:@//localhost:1521/XE" userId="LOUIS" password="123456"> </jdbcConnection> <javaModelGenerator targetPackage="com.example.model" targetDirectory="src/main/java"/> <sqlMapGenerator targetPackage="com.example.mapper" targetDirectory="src/main/resources"/> <javaClientGenerator type="XMLMAPPER" targetPackage="com.example.mapper" targetDirectory="src/main/java"/> <table tableName="users" domainObjectName="User"/> </context> </generatorConfiguration> ``` 3. **外部属性配置**: 为了提高灵活性,可以将数据库连接等敏感信息抽取到一个外部的`generator.properties`文件中。这样可以避免直接暴露在`generatorConfig.xml`中。例如,在`generator.properties`中配置如下内容: ```properties jdbc.driverLocation=D:\\maven\\com\\oracle\\ojdbc14\\10.2.0.4.0\\ojdbc14-10.2.0.4.0.jar jdbc.driverClass=oracle.jdbc.driver.OracleDriver jdbc.connectionURL=jdbc:oracle:thin:@//localhost:1521/XE jdbc.userId=LOUIS jdbc.password=123456 ``` 然后在`generatorConfig.xml`中引用这些属性: ```xml <jdbcConnection driverClass="${jdbc.driverClass}" connectionURL="${jdbc.connectionURL}" userId="${jdbc.userId}" password="${jdbc.password}"> </jdbcConnection> ``` 通过上述配置,MyBatis Generator插件能够正确运行并生成所需的MyBatis代码。 ---
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值