Navicat 根据表生成实体类字段和备注

SELECT
CONCAT('/** ', isc.column_comment, ' */') my_column_comment,
CONCAT('private ',
CASE
                                WHEN isc.data_type = 'varchar' or isc.data_type = 'char'  or isc.data_type = 'tinytext'  or isc.data_type = 'text'  or isc.data_type = 'longtext'   THEN
                                  'String'
                                WHEN isc.data_type = 'int' or isc.data_type = 'tinyint' or isc.data_type = 'integer' THEN
                                  'Integer'
                                WHEN isc.data_type = 'bigint' THEN
                                  'Long'
                                WHEN isc.data_type = 'datetime' THEN
                                  'Date'
                                WHEN isc.data_type = 'time' THEN
                                  'String'
                                WHEN isc.data_type = 'float' THEN
                                  'Double'
                                WHEN isc.data_type = 'decimal' THEN 
                                  'BigDecimal'
                                ELSE
                                  'String'
                              END,' ',
REPLACE(REPLACE(INITCAP(CONCAT('_',REPLACE(LOWER(isc.column_name),'_',' '))),'_',''),' ',''),
';',
CASE WHEN isc.data_type = 'datetime' THEN
CONCAT(' /** ', isc.column_comment,'字符串', ' */ ','private String ',
REPLACE(REPLACE(INITCAP(CONCAT('_',REPLACE(LOWER(isc.column_name),'_',' '))),'_',''),' ',''),'Str;')
ELSE '' END
)my_column
FROM
  information_schema.TABLES ist,
  information_schema.COLUMNS isc
WHERE ist.table_name = isc.table_name
  AND ist.table_schema = isc.table_schema
  AND ist.table_schema = 'yzsaas'
  -- AND ist.table_name LIKE 'ic_%'
  AND ist.table_name IN ('iqp_cno_account')
  ORDER BY ist.CREATE_TIME DESC,
  ist.table_name,ORDINAL_POSITION;
CREATE DEFINER=`yzsaas`@`%` FUNCTION `initcap`(ss VARCHAR (1000)) RETURNS varchar(1000) CHARSET utf8mb4
BEGIN
  DECLARE lena INT ;
  DECLARE pos INT ;
  DECLARE firsta CHAR(1) ;
  DECLARE seconda VARCHAR (999) ;
  DECLARE tmpstr VARCHAR (1000) ;
  DECLARE retstr VARCHAR (1000) ;
  IF (LENGTH(TRIM(ss)) = 0) 
  THEN RETURN '' ;
  END IF ;
  IF (RIGHT(ss, 1) != ' ') 
  THEN SET ss = CONCAT(ss, ' ') ;
  END IF ;
  SET pos = INSTR(ss, ' ') ;
  SET lena = LENGTH(ss) ;
  WHILE
    (pos > 0) DO SET tmpstr = TRIM(LEFT(ss, pos)) ;
    SET ss = RIGHT(ss, lena - pos) ;
    SET lena = LENGTH(tmpstr) ;
    SET firsta = UPPER(LEFT(tmpstr, 1)) ;
    SET seconda = LOWER(RIGHT(tmpstr, lena - 1)) ;
    IF (LENGTH(retstr) > 0) 
    THEN SET retstr = CONCAT(retstr, ' ', firsta, seconda) ;
    ELSE SET retstr = CONCAT(firsta, seconda) ;
    END IF ;
    SET pos = INSTR(ss, ' ') ;
    SET lena = LENGTH(ss) ;
  END WHILE ;
  RETURN retstr ;
END

转载于:https://my.oschina.net/u/2611678/blog/1817136

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
自己编写的实体类生成器 支持数据库oracle 和 SqlServer 支持实体类生成程序:C# 和 java *注意: 电脑上一定要安装 framework才能运行本软件 有什么问题请联系qq:910579826 备注添加:实体类生成器 1. 用户首先选择要操作的数据库,选中后程序会自动创建数据库连接字符串。 2.选择要生成实体类类型,程序会根据选中的类型自动生成相对应的实体类 3.在程序左侧会显示连接的数据库,选择要操作的数据库,会自动加载该数据库下的信息。 4.选择要操作的,在右侧会显示该中的字段信息 5.程序自动处理数据库中的书库类型,将其转换为程序相对应的可以识别的数据类型。 6.在字段显示窗体,用户还可以手动选择数据类型。 7.用户可以选择要生成字段信息,不想生成字段只要取消选中状态即可 8.选择生成文件保存的路径 9.设置要生成的包名或名称空间名 10.点击生成按钮。这时,弹出一个编辑实体类窗体,在这里可以对即将要生成实体类信息进行检查并修改信息。 11.修改完毕后,点击生成。完毕后提示生成成功! *备注:程序中每一步都有相对应的必要检测,当用户选择不符合必须选择或填写的信息时,将提示相对应的提示。 修改,创建操作时,都有确认提示。 说明: 根据数据库结构,自动生成实例类 支持的数据库:oracle和SQLServer 可生成实体类:C#实体类Java实体类 软件特点: 同时支持Oracle和SQLServer两种数据库 同时支持Java和C#程序的实体类生成 同时支持任意数据库搭配任意程序的实体类生成

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值