根据javabean转换为mysql建表语句

Posted jeffscnblog

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了根据javabean转换为mysql建表语句相关的知识,希望对你有一定的参考价值。

一般上,我们会使用数据库表转换为javabean、dao、或是mapper,就叫逆向工程。做项目时一般也是先设计数据库,再进行系统开发,所以一般使用逆向工程。

但我这边由于工作临时的需要,需要将javabean转换为建表语句,于是上网搜了一下,大部分是做一个工具类进行bean解析输出SQL语句。

根据自身项目命名设计要求,简化一个例子如下,供参考

package com.util;
import java.io.IOException;
import java.lang.reflect.Field;


/**
 * Created by Jeff on 2018/12/5.
 */
public class CreateTableUtil {
    /**
     * @param args
     * @throws IOException
     */
    public static void main(String[] args) throws IOException {
        createTable(com.entity.SharingFile.class, null);
    }

    public static void createTable(Class obj,String tableName) throws IOException{
        Field[] fields = null;
        fields = obj.getDeclaredFields();
        String param = null;
        String column = null;
        StringBuilder sb = null;
        sb = new StringBuilder(50);
        if(tableName==null||tableName.equals("")){
            //未传表明则默认用类名
            tableName = obj.getName();
            tableName = tableName.substring(tableName.lastIndexOf(".")+1);
        }
        sb.append("drop table if exists ").append(tableName).append(";
");
        sb.append("create table ").append(tableName).append(" ( 
");
        boolean firstId = true;
        for(Field f : fields){
            column = f.getName();
            for(int i = 0; i < column.length(); i++)
                if(Character.isUpperCase(column.charAt(i)))
                    column = column.substring(0, i) + ‘_‘ + column.substring(i, i+1).toLowerCase() + column.substring(i+1, column.length());

            sb.append(column).append(" ");
            param = f.getType().getTypeName();
            if(param.equals("java.lang.Integer")){
                sb.append("INTEGER");
            }else{
                sb.append("VARCHAR(20)");//根据需要自行修改
            }
            if(firstId){//类型转换
                sb.append(" PRIMARY KEY AUTO_INCREMENT");
                firstId = false;
            }
            sb.append(",
");
        }
        String sql = null;
        sql = sb.toString();
        sql = sb.substring(0, sql.length()-2)+"
)ENGINE = INNODB DEFAULT CHARSET= utf8 AUTO_INCREMENT=1;
";
        System.out.println(sql);
    }

}

 

以上是关于根据javabean转换为mysql建表语句的主要内容,如果未能解决你的问题,请参考以下文章

MySQL数据同步到HIVE,自动生成MySQL表对应HIVE的建表语句

python:sql建表语句转换为json

有两个地方,用到了javabean对象和属性字符串值之间的转换

mysql 建表语句

数据库系统概论(第5版)萨师煊.王珊代码mysql版本(建库建表查询语句)

sql sever怎么查看之前的建表语句