根据mybatis 的mapper.xml文件生成数据表结构

本文介绍了如何通过Java程序分析mybatis的mapper.xml文件,自动生成对应的数据表结构。主要利用JDOM库解析XML,针对不同字段类型设定默认长度,最后输出SQL创建表语句。
摘要由CSDN通过智能技术生成

遇到通过xml文件生成数据表的业务需求,自己用来记录一下。

直接干货:

package com.ruoyi.web.controller.demo.controller;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.io.StringReader;
import java.util.List;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;

import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.jdom.Document;
import org.jdom.Element;
import org.jdom.JDOMException;
import org.jdom.input.SAXBuilder;
import org.jdom.xpath.XPath;
import org.springframework.util.StringUtils;
import org.xml.sax.InputSource;
import org.xml.sax.SAXException;

public class Sqlmap2Table {

    // 默认所有的varchar都是512,可以保证满足绝大多数的字段  
    private static final String DEFAULT_VARCHAR_LENGTH = "VARCHAR(256)";

    
    public static void main(String[] args) throws Exception {
        String sqlMapPath = "D:/mapper";//这里指定你的sqlmap配置文件所在路径  
        analysis(sqlMapPath);
    }
    
    
    /* 根据指定的目录进行遍历分析 
    *  
    * @param path 
    * @throws IOException 
    * @throws JDOMException 
    */  
   private static void analysis(String path) throws IOException, JDOMException {  
       File filePath = new File(path);  
       if (filePath.isDirectory() && !filePath.getName().equals(".svn")) {  
           File[] fileList = filePath.listFiles();  
           for (File file : fileList) {  
               if (file.isDirectory()) {  
                   analysis(file.getAbsolutePath());  
               } else {  
                   analysisSqlMap(file.getAbsolutePath());  
               }  
           }  
     

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值