Mybatis Generator отсутствуют методы
Я обнаружил, что при подключении mariadb были некоторые недостающие методы в сгенерированном интерфейсе отображения.
public interface Mapper {
int insert(Record record);
int insertSelective(Record record);
}
что должно быть:
public interface Mapper {
int deleteByPrimaryKey(Record id);
int insert(Record record);
int insertSelective(Record record);
City selectByPrimaryKey(Record id);
int updateByPrimaryKeySelective(Record record);
int updateByPrimaryKey(Record record);
}
Я пробовал несколько разных библиотек коннекторов, как mysql-connector-java, так и mariadb-java-client. И сгенерированный код корректен при подключении mysql, это напоминает мне, если mybatis generator 1.3.6 не поддерживает mariadb 5.7.20? Кстати, версия MySQL была 5,7. вот мой 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="/maven/repo/org/mariadb/jdbc/mariadb-java-client/2.2.1/mariadb-java-client-2.2.1.jar" />
<context id="mybatisgen" targetRuntime="MyBatis3">
<commentGenerator>
<property name="suppressAllComments" value="true" />
<property name="suppressDate" value="true" />
</commentGenerator>
<jdbcConnection driverClass="org.mariadb.jdbc.Driver"
connectionURL="jdbc:mariadb://127.0.0.1:3306/db?characterEncoding=utf8"
userId="user"
password="password">
</jdbcConnection>
<javaTypeResolver >
<property name="forceBigDecimals" value="false" />
</javaTypeResolver>
<javaModelGenerator targetPackage="me.model" targetProject="src">
<property name="enableSubPackages" value="true" />
<property name="trimStrings" value="true" />
</javaModelGenerator>
<sqlMapGenerator targetPackage="me.mapper" targetProject="src">
<property name="enableSubPackages" value="true" />
</sqlMapGenerator>
<javaClientGenerator type="XMLMAPPER" targetPackage="me.dao" targetProject="src">
<property name="enableSubPackages" value="true" />
</javaClientGenerator>
<table tableName="test_table" domainObjectName="ATable"
enableCountByExample="false" enableUpdateByExample="false"
enableDeleteByExample="false" enableSelectByExample="false"
selectByExampleQueryId="false">
</table>
</context>
</generatorConfiguration>
1 ответ
Это происходит, когда MyBatis Generator не может получить информацию о первичном ключе от драйвера JDBC (он вызывает DatabaseMetaData.getPrimaryKeys).
Вы можете использовать плагин VirtualPrimaryKey (задокументированный по адресу http://www.mybatis.org/generator/reference/plugins.html), чтобы вручную указать первичный ключ для таблицы, когда драйвер JDBC не может вернуть эту информацию.