在用mybatis的generator自动生成代码时出现的问题

一抹浅蓝_ 2017-03-30 01:36:22
用的是eclipse的mybatis-generator-plugin插件,当表设置了catalog的时候,在生成的xml文件中会出现两个点。见下图:

...全文
244 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
nickycheng 2017-03-31
  • 打赏
  • 举报
回复
看generator源码 org.mybatis.generator.internal.util

    public static String composeFullyQualifiedTableName(String catalog,
            String schema, String tableName, char separator) {
        StringBuilder sb = new StringBuilder();

        if (stringHasValue(catalog)) {
            sb.append(catalog);
            sb.append(separator);
        }

        if (stringHasValue(schema)) {
            sb.append(schema);
            sb.append(separator);
        } else {
            if (sb.length() > 0) {
                sb.append(separator);
            }
        }

        sb.append(tableName);

        return sb.toString();
    }
你用的是mysql吧,mysql不支持schemas,也不支持catalog..tablename 这样的形式。so,要么改源代码,要么不用catalog。 改源代码可以用hot patch方式,用javassist,在generator执行前修改类方法,看起来比较简单些。 类似:

CtClass ctClass = classPool.get("org.mybatis.generator.internal.util.StringUtility");
        try {
            CtMethod m = ctClass.getDeclaredMethod("composeFullyQualifiedTableName");
            m.setBody("{return xxxx(修改代码);}");
            ctClass.toClass();
        } catch (Exception e) {
            //
        }

67,513

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧