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

相关推荐
水云桐程序员4 小时前
C++可以写手机应用吗
开发语言·c++·智能手机
测试员周周5 小时前
【AI测试智能体】为什么传统测试方法对智能体失效?
开发语言·人工智能·python·功能测试·测试工具·单元测试·测试用例
dfdfadffa5 小时前
如何用模块化方案组织一个可扩展的前端组件库项目
jvm·数据库·python
2301_812539675 小时前
SQL中如何高效实现分组数据的批量更新_利用窗口函数与JOIN
jvm·数据库·python
RSTJ_16255 小时前
PYTHON+AI LLM DAY THREETY-NINE
开发语言·人工智能·python
2501_901200535 小时前
如何实现SQL存储过程存储过程参数标准化_统一命名规范
jvm·数据库·python
运气好好的5 小时前
Golang怎么用embed嵌入SQL文件_Golang如何将SQL迁移文件嵌入Go程序统一管理【技巧】
jvm·数据库·python
AC赳赳老秦6 小时前
政企内网落地:OpenClaw 离线环境深度适配方案,无外网场景下本地化模型对接与全功能使用
java·大数据·运维·python·自动化·deepseek·openclaw
赏金术士6 小时前
Kotlin 从入门到进阶 之函数模块(核心基础)(二)
android·开发语言·kotlin
星越华夏6 小时前
python 将相对路径变成绝对路径
python