利用sql 生成 带swagger注解的实体

-- 设置参数:schema数据库

SET @table_schema='ibp_enrolment';

-- 设置参数:表名称

SET @table_name='bs_warehouse_file_config';

SELECT

CONCAT('@ApiModelProperty(value="',main.COLUMN_COMMENT,'")\n','private ',

CASE

WHEN LOWER(main.DATA_TYPE) LIKE 'varchar%' OR LOWER(main.DATA_TYPE) LIKE 'char%' OR LOWER(main.DATA_TYPE) LIKE 'LONGTEXT%' OR LOWER(main.DATA_TYPE) LIKE 'tinytext%' THEN 'String'

WHEN LOWER(main.DATA_TYPE) LIKE 'decimal%' OR LOWER(main.DATA_TYPE) = 'float'THEN 'Double'

WHEN LOWER(main.DATA_TYPE)='int' OR LOWER(main.DATA_TYPE)='tinyint' THEN 'Integer'

WHEN LOWER(main.DATA_TYPE)='bigint' THEN 'Long'

WHEN LOWER(main.DATA_TYPE)='datetime' OR LOWER(main.DATA_TYPE)='timestamp' THEN 'Timestamp'

WHEN LOWER(main.DATA_TYPE)='date' THEN 'Date'

ELSE ''

END,' ',

underlineToCamel(main.COLUMN_NAME),

'=',

CASE

WHEN LOWER(main.DATA_TYPE) LIKE 'varchar%' OR LOWER(main.DATA_TYPE) LIKE 'char%' THEN '\"\"'

WHEN LOWER(main.DATA_TYPE) LIKE 'decimal%' THEN IF(main.NUMERIC_SCALE=1,'0.0D',IF(main.NUMERIC_SCALE=2,'0.00D',IF(main.NUMERIC_SCALE=3,'0.000D',IF(main.NUMERIC_SCALE=4,'0.0000D','0.00D'))))

WHEN LOWER(main.DATA_TYPE) = 'float' THEN '0.0D'

WHEN LOWER(main.DATA_TYPE)='int' OR LOWER(main.DATA_TYPE)='tinyint' THEN '0'

WHEN LOWER(main.DATA_TYPE)='bigint' THEN '0L'

WHEN LOWER(main.DATA_TYPE)='datetime' OR LOWER(main.DATA_TYPE)='timestamp' THEN 'Timestamp.valueOf(LocalDateTime.now())'

WHEN LOWER(main.DATA_TYPE)='date' THEN 'Date.valueOf(LocalDate.now())'

ELSE ''

END,

';') AS VO,

CONCAT('/**\n','*',main.COLUMN_COMMENT,'\n*/\n',

CASE WHEN main.COLUMN_NAME='valid' THEN '@TableLogic(value = "0", delval = "1")\n@TableField(fill = FieldFill.INSERT)\n'

WHEN main.COLUMN_NAME='version' THEN '@Version\n@TableField(fill = FieldFill.INSERT_UPDATE)\n'

WHEN main.COLUMN_NAME='created_user_code' THEN '@TableField(fill = FieldFill.INSERT)\n'

WHEN main.COLUMN_NAME='created_time' THEN '@TableField(fill = FieldFill.INSERT)\n'

WHEN main.COLUMN_NAME='updated_user_code' THEN '@TableField(fill = FieldFill.INSERT_UPDATE)\n'

WHEN main.COLUMN_NAME='updated_time' THEN '@TableField(fill = FieldFill.INSERT_UPDATE)\n'

WHEN main.COLUMN_NAME='id' THEN '@TableId(type = IdType.AUTO)\n'

ELSE ''

END

,'private ',

CASE

WHEN LOWER(main.DATA_TYPE) LIKE 'varchar%' OR LOWER(main.DATA_TYPE) LIKE 'char%' OR LOWER(main.DATA_TYPE) LIKE 'LONGTEXT%' OR LOWER(main.DATA_TYPE) LIKE 'tinytext%' THEN 'String'

WHEN LOWER(main.DATA_TYPE) LIKE 'decimal%' OR LOWER(main.DATA_TYPE) = 'float'THEN 'Double'

WHEN LOWER(main.DATA_TYPE)='int' OR LOWER(main.DATA_TYPE)='tinyint' THEN 'Integer'

WHEN LOWER(main.DATA_TYPE)='bigint' THEN 'Long'

WHEN LOWER(main.DATA_TYPE)='datetime' OR LOWER(main.DATA_TYPE)='timestamp' THEN 'Timestamp'

WHEN LOWER(main.DATA_TYPE)='date' THEN 'Date'

ELSE ''

END,' ',

underlineToCamel(main.COLUMN_NAME),

'=',

CASE

WHEN LOWER(main.DATA_TYPE) LIKE 'varchar%' OR LOWER(main.DATA_TYPE) LIKE 'char%' THEN '\"\"'

WHEN LOWER(main.DATA_TYPE) LIKE 'decimal%' THEN IF(main.NUMERIC_SCALE=1,'0.0D',IF(main.NUMERIC_SCALE=2,'0.00D',IF(main.NUMERIC_SCALE=3,'0.000D',IF(main.NUMERIC_SCALE=4,'0.0000D','0.00D'))))

WHEN LOWER(main.DATA_TYPE) = 'float' THEN '0.0D'

WHEN LOWER(main.DATA_TYPE)='int' OR LOWER(main.DATA_TYPE)='tinyint' THEN '0'

WHEN LOWER(main.DATA_TYPE)='bigint' THEN '0L'

WHEN LOWER(main.DATA_TYPE)='datetime' OR LOWER(main.DATA_TYPE)='timestamp' THEN 'Timestamp.valueOf(LocalDateTime.now())'

WHEN LOWER(main.DATA_TYPE)='date' THEN 'Date.valueOf(LocalDate.now())'

ELSE ''

END,

';') AS 'Entity'

FROM

information_schema.`COLUMNS` main

WHERE

main.TABLE_SCHEMA = @table_schema

AND main.TABLE_NAME = @table_name;

其中转驼峰的函数underlineToCamel 如下:

CREATE DEFINER=`vx`@`%` FUNCTION `underlineToCamel`(paramString VARCHAR(200)) RETURNS varchar(200) CHARSET utf8

DETERMINISTIC

begin

set paramString = replace(paramString, '_a', 'A');

set paramString = replace(paramString, '_b', 'B');

set paramString = replace(paramString, '_c', 'C');

set paramString = replace(paramString, '_d', 'D');

set paramString = replace(paramString, '_e', 'E');

set paramString = replace(paramString, '_f', 'F');

set paramString = replace(paramString, '_g', 'G');

set paramString = replace(paramString, '_h', 'H');

set paramString = replace(paramString, '_i', 'I');

set paramString = replace(paramString, '_j', 'J');

set paramString = replace(paramString, '_k', 'K');

set paramString = replace(paramString, '_l', 'L');

set paramString = replace(paramString, '_m', 'M');

set paramString = replace(paramString, '_n', 'N');

set paramString = replace(paramString, '_o', 'O');

set paramString = replace(paramString, '_p', 'P');

set paramString = replace(paramString, '_q', 'Q');

set paramString = replace(paramString, '_r', 'R');

set paramString = replace(paramString, '_s', 'S');

set paramString = replace(paramString, '_t', 'T');

set paramString = replace(paramString, '_u', 'U');

set paramString = replace(paramString, '_v', 'V');

set paramString = replace(paramString, '_w', 'W');

set paramString = replace(paramString, '_x', 'X');

set paramString = replace(paramString, '_y', 'Y');

set paramString = replace(paramString, '_z', 'Z');

set paramString = replace(paramString, '_', '');

RETURN paramString;

end

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要快速基于数据库表生成实体类并自动加上swagger注解,可以采取以下步骤: 1. 首先,需要连接数据库,并读取数据库表的结构信息。可以使用数据库连接工具库如JDBC来连接数据库,使用相关API获取表的元数据信息。 2. 获取表的元数据后,可以通过遍历元数据来生成实体类。可以使用字符串拼接的方式,构建出实体类的代码。 3. 在生成实体类的过程中,需要根据元数据的类型和名称来决定实体类的字段类型和名称。根据元数据的类型,可以将数据库的数据类型转换为对应的Java类型。使用字符串拼接的方式,可以将字段类型、名称及其注解添加到实体类的代码中。 4. 在实体类中加入swagger注解,可以通过在生成实体类代码的过程中,根据表的元数据信息,判断是否应该添加swagger注解。根据元数据的属性,可以判断字段是否为必填项、字段的描述等。根据这些元数据属性,可以通过字符串拼接,将swagger注解的相关信息添加到实体类代码中。 5. 完成实体类的生成之后,可以将生成实体类保存到指定的路径。可以使用IO操作将生成的代码保存为Java文件。 6. 最后,通过编译器编译生成的Java文件,将其转换为字节码文件,并加载到JVM中即可。 通过以上步骤,可以快速基于数据库表生成实体类,并自动加上swagger注解。这样可以方便地生成实体类代码,并为API文档的编写提供便利。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值