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博客

相关推荐
该用户已不存在19 小时前
Mojo vs Python vs Rust: 2025年搞AI,该学哪个?
后端·python·rust
站大爷IP21 小时前
Java调用Python的5种实用方案:从简单到进阶的全场景解析
python
用户8356290780511 天前
从手动编辑到代码生成:Python 助你高效创建 Word 文档
后端·python
侃侃_天下1 天前
最终的信号类
开发语言·c++·算法
c8i1 天前
python中类的基本结构、特殊属性于MRO理解
python
echoarts1 天前
Rayon Rust中的数据并行库入门教程
开发语言·其他·算法·rust
liwulin05061 天前
【ESP32-CAM】HELLO WORLD
python
Aomnitrix1 天前
知识管理新范式——cpolar+Wiki.js打造企业级分布式知识库
开发语言·javascript·分布式
Doris_20231 天前
Python条件判断语句 if、elif 、else
前端·后端·python
Doris_20231 天前
Python 模式匹配match case
前端·后端·python