zoukankan      html  css  js  c++  java
  • mybatis反向生成sql,基本的增删改查

    用到的几个文件

    MyBatisGeneratorProxy.java

    package com.timestech.wsgk.test.tools;
    
    import static org.mybatis.generator.internal.util.ClassloaderUtility.getCustomClassloader;
    import static org.mybatis.generator.internal.util.messages.Messages.getString;
    
    import java.io.BufferedWriter;
    import java.io.File;
    import java.io.FileOutputStream;
    import java.io.IOException;
    import java.io.OutputStreamWriter;
    import java.sql.SQLException;
    import java.util.ArrayList;
    import java.util.HashSet;
    import java.util.List;
    import java.util.Set;
    
    import org.mybatis.generator.api.GeneratedJavaFile;
    import org.mybatis.generator.api.GeneratedXmlFile;
    import org.mybatis.generator.api.ProgressCallback;
    import org.mybatis.generator.api.ShellCallback;
    import org.mybatis.generator.config.Configuration;
    import org.mybatis.generator.config.Context;
    import org.mybatis.generator.config.MergeConstants;
    import org.mybatis.generator.exception.InvalidConfigurationException;
    import org.mybatis.generator.exception.ShellException;
    import org.mybatis.generator.internal.DefaultShellCallback;
    import org.mybatis.generator.internal.NullProgressCallback;
    import org.mybatis.generator.internal.ObjectFactory;
    import org.mybatis.generator.internal.XmlFileMergerJaxp;
    
    public class MyBatisGeneratorProxy {
    
        private Configuration configuration;
    
        private ShellCallback shellCallback;
    
        private List<GeneratedJavaFile> generatedJavaFiles;
    
        private List<GeneratedXmlFile> generatedXmlFiles;
    
        private List<String> warnings;
    
        private Set<String> projects;
    
        /**
         * Constructs a MyBatisGenerator object.
         * 
         * @param configuration
         *            The configuration for this invocation
         * @param shellCallback
         *            an instance of a ShellCallback interface. You may specify
         *            <code>null</code> in which case the DefaultShellCallback will
         *            be used.
         * @param warnings
         *            Any warnings generated during execution will be added to this
         *            list. Warnings do not affect the running of the tool, but they
         *            may affect the results. A typical warning is an unsupported
         *            data type. In that case, the column will be ignored and
         *            generation will continue. You may specify <code>null</code> if
         *            you do not want warnings returned.
         * @throws InvalidConfigurationException
         *             if the specified configuration is invalid
         */
        public MyBatisGeneratorProxy(Configuration configuration, ShellCallback shellCallback,
                List<String> warnings) throws InvalidConfigurationException {
            super();
            if (configuration == null) {
                throw new IllegalArgumentException(getString("RuntimeError.2")); //$NON-NLS-1$
            } else {
                this.configuration = configuration;
            }
    
            if (shellCallback == null) {
                this.shellCallback = new DefaultShellCallback(false);
            } else {
                this.shellCallback = shellCallback;
            }
    
            if (warnings == null) {
                this.warnings = new ArrayList<String>();
            } else {
                this.warnings = warnings;
            }
            generatedJavaFiles = new ArrayList<GeneratedJavaFile>();
            generatedXmlFiles = new ArrayList<GeneratedXmlFile>();
            projects = new HashSet<String>();
    
            this.configuration.validate();
        }
    
        /**
         * This is the main method for generating code. This method is long running,
         * but progress can be provided and the method can be canceled through the
         * ProgressCallback interface. This version of the method runs all
         * configured contexts.
         * 
         * @param callback
         *            an instance of the ProgressCallback interface, or
         *            <code>null</code> if you do not require progress information
         * @throws SQLException
         * @throws IOException
         * @throws InterruptedException
         *             if the method is canceled through the ProgressCallback
         */
        public void generate(ProgressCallback callback) throws SQLException,
                IOException, InterruptedException {
            generate(callback, null, null);
        }
    
        /**
         * This is the main method for generating code. This method is long running,
         * but progress can be provided and the method can be canceled through the
         * ProgressCallback interface.
         * 
         * @param callback
         *            an instance of the ProgressCallback interface, or
         *            <code>null</code> if you do not require progress information
         * @param contextIds
         *            a set of Strings containing context ids to run. Only the
         *            contexts with an id specified in this list will be run. If the
         *            list is null or empty, than all contexts are run.
         * @throws InvalidConfigurationException
         * @throws SQLException
         * @throws IOException
         * @throws InterruptedException
         *             if the method is canceled through the ProgressCallback
         */
        public void generate(ProgressCallback callback, Set<String> contextIds)
                throws SQLException, IOException, InterruptedException {
            generate(callback, contextIds, null);
        }
    
        /**
         * This is the main method for generating code. This method is long running,
         * but progress can be provided and the method can be cancelled through the
         * ProgressCallback interface.
         * 
         * @param callback
         *            an instance of the ProgressCallback interface, or
         *            <code>null</code> if you do not require progress information
         * @param contextIds
         *            a set of Strings containing context ids to run. Only the
         *            contexts with an id specified in this list will be run. If the
         *            list is null or empty, than all contexts are run.
         * @param fullyQualifiedTableNames
         *            a set of table names to generate. The elements of the set must
         *            be Strings that exactly match what's specified in the
         *            configuration. For example, if table name = "foo" and schema =
         *            "bar", then the fully qualified table name is "foo.bar". If
         *            the Set is null or empty, then all tables in the configuration
         *            will be used for code generation.
         * @throws InvalidConfigurationException
         * @throws SQLException
         * @throws IOException
         * @throws InterruptedException
         *             if the method is canceled through the ProgressCallback
         */
        public void generate(ProgressCallback callback, Set<String> contextIds,
                Set<String> fullyQualifiedTableNames) throws SQLException,
                IOException, InterruptedException {
    
            if (callback == null) {
                callback = new NullProgressCallback();
            }
    
            generatedJavaFiles.clear();
            generatedXmlFiles.clear();
    
            // calculate the contexts to run
            List<Context> contextsToRun;
            if (contextIds == null || contextIds.size() == 0) {
                contextsToRun = configuration.getContexts();
            } else {
                contextsToRun = new ArrayList<Context>();
                for (Context context : configuration.getContexts()) {
                    if (contextIds.contains(context.getId())) {
                        contextsToRun.add(context);
                    }
                }
            }
    
            // setup custom classloader if required
            if (configuration.getClassPathEntries().size() > 0) {
                ClassLoader classLoader = getCustomClassloader(configuration.getClassPathEntries());
                ObjectFactory.addExternalClassLoader(classLoader);
            }
    
            // now run the introspections...
            int totalSteps = 0;
            for (Context context : contextsToRun) {
                totalSteps += context.getIntrospectionSteps();
            }
            callback.introspectionStarted(totalSteps);
    
            for (Context context : contextsToRun) {
                context.introspectTables(callback, warnings,
                        fullyQualifiedTableNames);
            }
    
            // now run the generates
            totalSteps = 0;
            for (Context context : contextsToRun) {
                totalSteps += context.getGenerationSteps();
            }
            callback.generationStarted(totalSteps);
    
            for (Context context : contextsToRun) {
                context.generateFiles(callback, generatedJavaFiles,
                        generatedXmlFiles, warnings);
            }
    
            // now save the files
            callback.saveStarted(generatedXmlFiles.size()
                    + generatedJavaFiles.size());
    
            for (GeneratedXmlFile gxf : generatedXmlFiles) {
                projects.add(gxf.getTargetProject());
    
                File targetFile;
                String source;
                try {
                    File directory = shellCallback.getDirectory(gxf
                            .getTargetProject(), gxf.getTargetPackage());
                    targetFile = new File(directory, gxf.getFileName());
                    if (targetFile.exists()) {
                        if (gxf.isMergeable()) {
                            source = XmlFileMergerJaxp.getMergedSource(gxf,
                                    targetFile);
                        } else if (shellCallback.isOverwriteEnabled()) {
                            source = gxf.getFormattedContent();
                            warnings.add(getString("Warning.11", //$NON-NLS-1$
                                    targetFile.getAbsolutePath()));
                        } else {
                            source = gxf.getFormattedContent();
                            targetFile = getUniqueFileName(directory, gxf
                                    .getFileName());
                            warnings.add(getString(
                                    "Warning.2", targetFile.getAbsolutePath())); //$NON-NLS-1$
                        }
                    } else {
                        source = gxf.getFormattedContent();
                    }
                } catch (ShellException e) {
                    warnings.add(e.getMessage());
                    continue;
                }
    
                callback.checkCancel();
                callback.startTask(getString(
                        "Progress.15", targetFile.getName())); //$NON-NLS-1$
                writeFile(targetFile, source, "UTF-8"); //$NON-NLS-1$
            }
    
            for (GeneratedJavaFile gjf : generatedJavaFiles) {
                projects.add(gjf.getTargetProject());
    
                File targetFile;
                String source;
                String fileName;
                try {
                    fileName = gjf.getFileName();
                    File directory = shellCallback.getDirectory(gjf
                            .getTargetProject(), gjf.getTargetPackage());
                    targetFile = new File(directory, fileName);
                    if (targetFile.exists()) {
                        if (shellCallback.isMergeSupported()) {
                            source = shellCallback.mergeJavaFile(gjf
                                    .getFormattedContent(), targetFile
                                    .getAbsolutePath(),
                                    MergeConstants.OLD_ELEMENT_TAGS,
                                    gjf.getFileEncoding());
                        } else if (shellCallback.isOverwriteEnabled()) {
                            source = gjf.getFormattedContent();
                            warnings.add(getString("Warning.11", //$NON-NLS-1$
                                    targetFile.getAbsolutePath()));
                        } else {
                            source = gjf.getFormattedContent();
                            targetFile = getUniqueFileName(directory, fileName);
                            warnings.add(getString(
                                    "Warning.2", targetFile.getAbsolutePath())); //$NON-NLS-1$
                        }
                    } else {
                        source = gjf.getFormattedContent();
                    }
                    if(!fileName.equals(gjf.getFileName())){
                        source = source.replace("interface " + gjf.getFileName().substring(0,gjf.getFileName().indexOf(".")), 
                                "interface " + fileName.substring(0,fileName.indexOf(".")));
                    }
                    callback.checkCancel();
                    callback.startTask(getString(
                            "Progress.15", targetFile.getName())); //$NON-NLS-1$
                    writeFile(targetFile, source, gjf.getFileEncoding());
                } catch (ShellException e) {
                    warnings.add(e.getMessage());
                }
            }
    
            for (String project : projects) {
                shellCallback.refreshProject(project);
            }
    
            callback.done();
        }
    
        /**
         * Writes, or overwrites, the contents of the specified file
         * 
         * @param file
         * @param content
         */
        private void writeFile(File file, String content, String fileEncoding) throws IOException {
            FileOutputStream fos = new FileOutputStream(file, false);
            OutputStreamWriter osw;
            if (fileEncoding == null) {
                osw = new OutputStreamWriter(fos);
            } else {
                osw = new OutputStreamWriter(fos, fileEncoding);
            }
            
            BufferedWriter bw = new BufferedWriter(osw);
            bw.write(content);
            bw.close();
        }
    
        private File getUniqueFileName(File directory, String fileName) {
            File answer = null;
    
            // try up to 1000 times to generate a unique file name
            StringBuilder sb = new StringBuilder();
            for (int i = 1; i < 1000; i++) {
                sb.setLength(0);
                sb.append(fileName);
                sb.append('.');
                sb.append(i);
    
                File testFile = new File(directory, sb.toString());
                if (!testFile.exists()) {
                    answer = testFile;
                    break;
                }
            }
    
            if (answer == null) {
                throw new RuntimeException(getString(
                        "RuntimeError.3", directory.getAbsolutePath())); //$NON-NLS-1$
            }
    
            return answer;
        }
    }

    MyBatisGeneratorTool.java---------run as 这个文件即可生成

    package com.timestech.wsgk.test.tools;
    
    import java.io.File;
    import java.io.IOException;
    import java.io.UnsupportedEncodingException;
    import java.sql.SQLException;
    import java.util.ArrayList;
    import java.util.List;
    
    import org.mybatis.generator.config.Configuration;
    import org.mybatis.generator.config.xml.ConfigurationParser;
    import org.mybatis.generator.exception.InvalidConfigurationException;
    import org.mybatis.generator.exception.XMLParserException;
    import org.mybatis.generator.internal.DefaultShellCallback;
    
    public class MyBatisGeneratorTool {
    
        public static void main(String[] args) throws UnsupportedEncodingException {  
            List<String> warnings = new ArrayList<String>();  
            boolean overwrite = true;  
            String genCfg = "/generator.xml"; //src/*/resources的一级目录下  
            File configFile = new File(java.net.URLDecoder.decode(MyBatisGeneratorTool.class.getResource(genCfg).getFile(),"utf-8"));  
            ConfigurationParser cp = new ConfigurationParser(warnings);  
            Configuration config = null;  
            try {  
                config = cp.parseConfiguration(configFile);  
            } catch (IOException e) {  
                e.printStackTrace();  
            } catch (XMLParserException e) {  
                e.printStackTrace();  
            }  
            DefaultShellCallback callback = new DefaultShellCallback(overwrite);  
            MyBatisGeneratorProxy myBatisGenerator = null;  
            try {  
                myBatisGenerator = new MyBatisGeneratorProxy(config, callback, warnings);  
            } catch (InvalidConfigurationException e) {  
                e.printStackTrace();  
            }  
            try {
                System.out.println("begin generate......");
                myBatisGenerator.generate(null);
                System.out.println("end generate......");
            } catch (SQLException e) {  
                e.printStackTrace();  
            } catch (IOException e) {  
                e.printStackTrace();  
            } catch (InterruptedException e) {  
                e.printStackTrace();  
            }  
        }  
    }

    generator.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="generatorConfig.properties"/>
        <classPathEntry location="${oracle.classPath}" />
    
        <context id="Mysql2Tables" targetRuntime="MyBatis3">
            <!-- 过滤掉注释 -->
            <commentGenerator>
                  <property name="suppressAllComments" value="true" />
                  <property name="suppressDate" value="true" />
            </commentGenerator>
            
            <!-- 数据链接 -->
            <jdbcConnection driverClass="${oracle.driverClass}"
                connectionURL="${oracle.connectionURL}" 
                userId="${oracle.userId}"
                password="${oracle.password}">
            </jdbcConnection>
    
            <!-- 根据数据库字段长度自动匹配,默认为false:bigdecimal,long,int,short ,为true时始终使用bigdecimal -->
            <javaTypeResolver>
                <property name="forceBigDecimals" value="false" />
            </javaTypeResolver>
            
            <!-- domain类的生成 -->
            <javaModelGenerator targetPackage="${oracle.modelPackage}"
                targetProject="src/main/java">
                <!-- 是否允许在targetPackage目录下建子目录 -->
                <property name="enableSubPackages" value="false" />
                <property name="trimStrings" value="true" />
            </javaModelGenerator>
    
            <!-- mapper文件生成 -->
            <sqlMapGenerator targetPackage="${oracle.sqlMapperPackage}"
                targetProject="src/main/java">
                <!-- 是否允许在targetPackage目录下建子目录 -->
                <property name="enableSubPackages" value="false" />
            </sqlMapGenerator>
    
            <!-- DAO生成 -->
            <javaClientGenerator type="XMLMAPPER"
                targetPackage="${oracle.daoMapperPackage}" targetProject="src/main/java">
                <!-- 是否允许在targetPackage目录下建子目录 -->
                <property name="enableSubPackages" value="false" />
                <property name="trimStrings" value="true" />
            </javaClientGenerator>
    
            <!-- 对应的数据库的哪张表,多个表的话就写多个table -->
            <table schema="bjlt" tableName="${oracle.tableName}" domainObjectName="${oracle.domainName}"
                enableCountByExample="false" enableUpdateByExample="false"
                enableDeleteByExample="false" enableSelectByExample="false"
                selectByExampleQueryId="false">
                <!-- 指定id字段是Long类型,而不是BigDecimal类型 -->
                <columnOverride column="id" javaType="Long" />
            </table>
    
        </context>
    </generatorConfiguration>

    generatorConfig.properties-----生成文件的位置什么的在这里配置

    #MYSQL数据库驱动
    mysql.classPath=C:/Users/Administrator/.m2/repository/mysql/mysql-connector-java/5.1.30/mysql-connector-java-5.1.30.jar
    #targetProject=D:/ylink/myeclipse/MBG/src
    mysql.driverClass=com.mysql.jdbc.Driver
    #链接数据库url
    mysql.connectionURL=jdbc:mysql://192.168.0.121:3306/bjlt
    #用户名
    mysql.userId=root
    #密码
    mysql.password=root
    #表名称
    mysql.tableName=test
    #domain名称
    mysql.domainName=test
    #domain类生成路径
    mysql.modelPackage=com.timestech.wsgk.web.model
    #mapper文件生成路径
    mysql.sqlMapperPackage=com.timestech.wsgk.web.mapper
    #DAO类生成路径
    mysql.daoMapperPackage=com.timestech.wsgk.web.dao
    
    #ORACLE数据库驱动
    oracle.classPath=C:/Users/Administrator/.m2/repository/com/oracle/ojdbc14/10.1.3/ojdbc14-10.1.3.jar
    #targetProject=D:/ylink/myeclipse/MBG/src
    oracle.driverClass=oracle.jdbc.driver.OracleDriver
    #链接数据库url
    oracle.connectionURL=jdbc:oracle:thin:@192.168.0.121:1521:orcl
    #用户名
    oracle.userId=bjlt
    #密码
    oracle.password=bjlt
    #表名称
    oracle.tableName=BASESTATION
    #domain名称
    oracle.domainName=BASESTATION
    #domain类生成路径
    oracle.modelPackage=com.timestech.wsgk.web.model
    #mapper文件生成路径
    oracle.sqlMapperPackage=com.timestech.wsgk.web.mapper
    #DAO类生成路径
    oracle.daoMapperPackage=com.timestech.wsgk.web.dao
  • 相关阅读:
    双击返回 退出程序
    读取InputStream 中的内容
    wsgi服务器
    python 中的GIL
    json
    __getattr__
    错误类型
    __slot__用法
    获取属性以及基本方法
    linux IO
  • 原文地址:https://www.cnblogs.com/zrui-xyu/p/5484627.html
Copyright © 2011-2022 走看看