根据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的建表语句
有两个地方,用到了javabean对象和属性字符串值之间的转换