mybatis生成器"列名模式不能为NULL或为空"

Try*_*est 6 mysql mybatis mybatis-generator

我在eclipse中使用MyBatis Generator.这是generatorConfig.xml文件.当我右键单击并选择"生成MyBatis工件"时,它会显示错误消息,如"列名模式不能为NULL或为空".

<?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="C:\Users\myplace\.m2\repository\mysql\mysql-connector-java\6.0.2\mysql-connector-java-6.0.2.jar" />
  <context id="context1">
  <plugin type="org.mybatis.generator.plugins.SerializablePlugin" />
        <plugin type="org.mybatis.generator.plugins.ToStringPlugin" />
  <jdbcConnection driverClass="com.mysql.jdbc.Driver"
            connectionURL="jdbc:mysql://localhost:3306/world?serverTimezone=EST"
            userId="root" password="root" />
    <javaModelGenerator targetPackage="com.example.ws.model" targetProject="com.example.ws" />
    <sqlMapGenerator targetPackage="com.example.ws.sql" targetProject="com.example.ws" />
   <javaClientGenerator targetPackage="com.example.ws.mapper" targetProject="com.example.ws" type="ANNOTATEDMAPPER" />
    <table schema="world" tableName="city">
      <columnOverride column="ID" property="id" javaType = "Integer" />
      <columnOverride column="Name" property="name" javaType = "String" />
      <columnOverride column="CuntryCode" property="cuntryCode" javaType = "String" />     
      <columnOverride column="District" property="district" javaType = "String" />
      <columnOverride column="Population" property="population" javaType = "BigDecimal" />
     </table>
  </context>
</generatorConfiguration>
Run Code Online (Sandbox Code Playgroud)

你能帮帮我吗?谢谢!

Jan*_*Jan 12

这是MySQL Connector从版本5.x到6.x的更改,如此处所述.

为了使MyBatis能够与6.x一起使用,您可以附加nullNamePatternMatchesAll=true到JDBC字符串.您可能必须在XML中转义&to &amp;.


商叶华*_*商叶华 5

我之前遇到过同样的错误.它可能是由db驱动程序引起的.在我将mysql-connector从6.0.3更改为5.1.38后,它再也没有出来.

您可以尝试更改您的mysql连接器.