使用jsqlparser创建MySQL建表语句

语法

create table [IF NOT EXISTS] 表名 (

字段名 类型 [约束条件],

字段名 类型 [约束条件],

字段名 类型 [约束条件],

字段名 类型 [约束条件]

);

  • 字段定义在括号内
  • 约束条件可以有多个
  • 多个字段定义之间用都会隔开

常见约束

  • NOT NULL 非空
  • DEFAULT 0 默认值
  • AUTO_INCREMENT 自增长
  • PRIMARY KEY 主键

示例

sql 复制代码
create table if not exists t_one (
  id bigint(20) UNSIGNED NOT NULL auto_increment primary key COMMENT '主键',
  name varchar(64) COMMENT '名称',
  age int(10) COMMENT '仙人寿命'
) engine=innoDB default charset=utf8mb4;

Jsqlparser创建建表语句

引入依赖

xml 复制代码
     <dependency>
         <groupId>com.github.jsqlparser</groupId>
         <artifactId>jsqlparser</artifactId>
         <version>4.3</version>
     </dependency>

Demo

java 复制代码
import net.sf.jsqlparser.schema.Table;
import net.sf.jsqlparser.statement.create.table.ColDataType;
import net.sf.jsqlparser.statement.create.table.ColumnDefinition;
import net.sf.jsqlparser.statement.create.table.CreateTable;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;

public class CreateTableDemo {
    public static void main(String[] args)throws Exception {
        CreateTable createTable = new CreateTable();
        // 设置表名
        Table table = new Table("t_one");
        createTable.setTable(table);
        // 定义字段
        // id
        ColDataType bigint = new ColDataType("BIGINT");
        bigint.setArgumentsStringList(Collections.singletonList("20"));
        ColumnDefinition id = new ColumnDefinition("id", bigint);
        id.setColumnSpecs(Arrays.asList("UNSIGNED", "NOT NULL", "PRIMARY KEY", "AUTO_INCREMENT", "COMMENT '主键'"));
        // name
        ColDataType varchar = new ColDataType("VARCHAR");
        varchar.setArgumentsStringList(Collections.singletonList("64"));
        ColumnDefinition name = new ColumnDefinition("name", varchar);
        name.setColumnSpecs(Collections.singletonList("COMMENT '名字'"));
        // age
        ColDataType anInt = new ColDataType("INT");
        ColumnDefinition age = new ColumnDefinition("age", anInt);
        age.setColumnSpecs(Collections.singletonList("COMMENT '仙人年龄'"));
        // 设置字段
        List<ColumnDefinition> columnDefinitionList = new ArrayList<>();
        columnDefinitionList.add(id);
        columnDefinitionList.add(name);
        columnDefinitionList.add(age);
        createTable.setColumnDefinitions(columnDefinitionList);
        // 设置IF NOT EXISTS
        createTable.setIfNotExists(true);
        // 设置引擎、字符集、排序规则
        createTable.setTableOptionsStrings(Arrays.asList("ENGINE = InnoDB", "CHARACTER SET = utf8mb4", "COLLATE = utf8mb4_general_ci"));
        // 打印建表语句
        System.out.println(createTable);
    }
}

结果:

sql 复制代码
CREATE TABLE IF NOT EXISTS t_one (id BIGINT (20) UNSIGNED NOT NULL PRIMARY KEY AUTO_INCREMENT COMMENT '主键', name VARCHAR (64) COMMENT '名字', age INT COMMENT '仙人年龄') ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci
相关推荐
倔强的石头_13 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
阿巴斯甜19 小时前
Android 报错:Zip file '/Users/lyy/develop/repoAndroidLapp/l-app-android-ble/app/bu
android
Kapaseker19 小时前
实战 Compose 中的 IntrinsicSize
android·kotlin
xq952720 小时前
Andorid Google 登录接入文档
android
黄林晴21 小时前
告别 Modifier 地狱,Compose 样式系统要变天了
android·android jetpack
冬奇Lab1 天前
Android触摸事件分发、手势识别与输入优化实战
android·源码阅读
城东米粉儿2 天前
Android MediaPlayer 笔记
android
Jony_2 天前
Android 启动优化方案
android
阿巴斯甜2 天前
Android studio 报错:Cause: error=86, Bad CPU type in executable
android
张小潇2 天前
AOSP15 Input专题InputReader源码分析
android