mybatis-generator代码生成报错

service模块依赖了common模块,他两个是同级的子模块,然后用mybatis-generator插件去生成代码报错,这种怎么解决

img

不知道你这个问题是否已经解决, 如果还没有解决的话:

  • 您还可以看一下 吴林峰老师的带大家读源码——mybatis generator第一期课程中的 mybatis-generator源码分析-生成文件上小节, 巩固相关知识点
  • 以下回答来自chatgpt:

    针对问题描述中提到的在service模块中引用了common模块,这两个模块是同级的子模块的情况,可以尝试以下解决方案:

    1. 在common模块中定义Mybatis-generator的config.xml文件,指定相关配置;
    2. 在service模块中的pom.xml中引入common模块的依赖;
    3. 在service模块中配置maven插件,引用common模块定义的Mybatis-generator的配置文件。

    具体操作步骤如下:

    1. 在common模块中定义Mybatis-generator的config.xml文件(例如,存放路径为src/main/resources/mybatis-generator-config.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>
        <classPathEntry location="${env.M2_REPO}/mysql/mysql-connector-java/5.1.47/mysql-connector-java-5.1.47.jar" />
        <context id="mybatis-generator">
            <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="${jdbc.url}"
                userId="${jdbc.username}" password="${jdbc.password}">
            </jdbcConnection>
            <javaTypeResolver>
                <property name="forceBigDecimals" value="false" />
            </javaTypeResolver>
            <javaModelGenerator targetPackage="com.example.model" targetProject="${project.location}/src/main/java">
                <property name="enableSubPackages" value="true" />
                <property name="trimStrings" value="true" />
            </javaModelGenerator>
            <sqlMapGenerator targetPackage="com.example.mapper" targetProject="${project.location}/src/main/java">
                <property name="enableSubPackages" value="true" />
            </sqlMapGenerator>
            <javaClientGenerator targetPackage="com.example.dao" targetProject="${project.location}/src/main/java"
                type="XMLMAPPER">
                <property name="enableSubPackages" value="true" />
            </javaClientGenerator>
            <table tableName="t_my_table_name"></table>
        </context>
    </generatorConfiguration>
    
    1. 在service模块的pom.xml中引入common模块的依赖,例如:
    <dependencies>
        <dependency>
            <groupId>com.example</groupId>
            <artifactId>common</artifactId>
            <version>1.0.0</version>
        </dependency>
    </dependencies>
    
    1. 在service模块中配置maven插件,引用common模块定义的Mybatis-generator的配置文件,例如:
    <build>
        <plugins>
            <plugin>
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-maven-plugin</artifactId>
                <version>1.3.2</version>
                <dependencies>
                    <dependency>
                        <groupId>com.example</groupId>
                        <artifactId>common</artifactId>
                        <version>1.0.0</version>
                    </dependency>
                </dependencies>
                <configuration>
                    <verbose>true</verbose>
                    <overwrite>true</overwrite>
                    <configurationFile>${project.basedir}/../common/src/main/resources/mybatis-generator-config.xml</configurationFile>
                </configuration>
            </plugin>
        </plugins>
    </build>
    

    其中,configurationFile指定了config.xml文件的路径,这里使用了相对路径,如果不行可以用绝对路径。

    通过以上步骤,就可以在service模块中引用common模块定义的Mybatis-generator的配置文件,生成相应的代码。


如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^

1、确保common模块已正确引入:检查service模块的依赖配置文件(如pom.xml)中是否正确引入了common模块,并且版本号等配置信息也正确。
2、检查common模块的可见性:确保common模块对于service模块是可见的。您可以检查common模块的访问修饰符是否为public,或者将common模块添加到service模块的构建路径中。
3、检查mybatis-generator配置:确认您正确配置了mybatis-generator插件。您可以检查相关的配置文件(如generatorConfig.xml)中的数据库连接信息、生成的实体类路径等配置是否正确。
4、检查生成的代码目录:确认生成的代码目录是否正确配置。您可以检查mybatis-generator插件的相关配置中的targetProject和targetPackage等属性是否正确指定了目标位置。
5、检查数据库连接:确保您的数据库连接是正确的,可以连接成功。如果数据库连接有误,可能导致生成代码时报错。