Java 常用工具类(35) : json转表结构ddl

java 复制代码
import com.alibaba.fastjson.JSONObject;
import com.alibaba.gts.flm.base.util.MysqlUtil;
import com.alibaba.gts.flm.base.util.StringUtils;

import java.util.Set;

public class Json转表结构 {

    private static JSONObject j;

    public static void main(String[] args) {
        j = JSONObject.parseObject(s);

        Set<String> keys = j.keySet();

        StringBuffer ddl = new StringBuffer();
        ddl.append("CREATE TABLE lkyw_vehicle_info (\n" +
                "  `pkid` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键id',\n" +
                "  `create_time` datetime DEFAULT NULL COMMENT '创建时间',\n" +
                "  `modify_time` datetime DEFAULT NULL COMMENT '修改时间',\n");
        // 遍历键并获取其类型
        for (String key : keys) {
            Class<?> keyType = j.get(key).getClass();
            String xhx = StringUtils.tuoFengToxiaHuaXian(key);
            ddl.append("  `" + xhx + "` " + MysqlUtil.getMysqlType(getJavaObject(keyType.toString())) + " DEFAULT NULL COMMENT '" + "" + "',\n");
        }

        ddl.append(
                "  PRIMARY KEY (`pkid`)\n" +
                        ") ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 COMMENT='';");
        System.out.println(ddl);
    }

    public static String getJavaObject(String kt) {
        switch (kt) {
            case "java.lang.String":
                return "String";
            case "java.lang.Integer":
            case "java.lang.Long":
                return "Long";
            case "java.lang.Float":
            case "java.lang.Double":
            case "class java.math.BigDecimal":
                return "Double";
            default:
                break;
        }
        return "String";
    }

    public static String s = "{\n" +
            "            \"age\": \"6\",\n" +
            "            \"name\": \"张三\",\n" +
            "            \"speed\": 553.8017520000001,\n" +
            "            \"lng\": 103.980244,\n" +
            "            \"lat\": 30.694589\n" +
            "        }";
}
复制代码
MysqlUtil
java 复制代码
import java.util.LinkedList;
import java.util.List;

/**
 * @Author: liyue
 * @Date: 2022/08/17/11:39
 * @Description:
 */
public class MysqlUtil {
    public static final List<String> types = new LinkedList<String>() {{
        add("tinyint");
        add("int");
        add("integer");
        add("bigint");
        add("float");
        add("double");
        add("char");
        add("varchar");
        add("datetime");
        add("text");
    }};

    public static String getJavaType(String mysqlType) {
        switch (mysqlType) {
            case "tinyint":
            case "int":
            case "integer":
                return "Integer";
            case "bigint":
                return "Long";
            case "float":
                return "Float";
            case "double":
                return "Double";
            case "text":
            case "char":
            case "varchar":
            case "datetime":
                return "String";
            default:
                throw new RuntimeException("未找到与java映射的类型");
        }
    }

    public static String getMysqlType(String javaType) {
        switch (javaType) {
            case "String":
                return "varchar(100)";
            case "Long":
                return "bigint";
            case "Double":
                return "double";
            case "double":
                return "Double";
            default:
                throw new RuntimeException("未找到与mysql映射的类型");
        }
    }
}
复制代码
StringUtils

Java 常用工具类(22) : 字符串处理_java 字符处理 工具包-CSDN博客

相关推荐
冷雨夜中漫步5 小时前
Python快速入门(6)——for/if/while语句
开发语言·经验分享·笔记·python
郝学胜-神的一滴6 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
百锦再6 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
m0_736919107 小时前
C++代码风格检查工具
开发语言·c++·算法
喵手8 小时前
Python爬虫实战:旅游数据采集实战 - 携程&去哪儿酒店机票价格监控完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集结果csv导出·旅游数据采集·携程/去哪儿酒店机票价格监控
2501_944934738 小时前
高职大数据技术专业,CDA和Python认证优先考哪个?
大数据·开发语言·python
helloworldandy8 小时前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
黎雁·泠崖8 小时前
【魔法森林冒险】5/14 Allen类(三):任务进度与状态管理
java·开发语言
2301_763472469 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
肖永威9 小时前
macOS环境安装/卸载python实践笔记
笔记·python·macos