mysql 生成bean_mysql 生成java bean 类

CREATE PROCEDURE `proc_generate_api_bean`(IN in_table varchar(1000))

BEGIN

select CONCAT('@Entity\n','@Table(name=\"',in_table,'\")\n','public class ',func_humpString(in_table,'_'),'{','\n') from dual

union

select DISTINCT

concat(

'\t/** ',c.COLUMN_COMMENT,'*/ \n',

if (c.ORDINAL_POSITION = 1,'\t@Id \n\t@GeneratedValue\n',''),

if (c.DATA_TYPE = 'DATETIME','\t@Convert(converter = LocalDateTimeConverter.class) \n',''),

'\t@Column(name =\"',c.COLUMN_NAME,'\") \n',

'\tprivate ' ,(

case

when c.DATA_TYPE = 'LONGTEXT' then

'String '

when c.DATA_TYPE = 'VARCHAR' then

'String '

when c.DATA_TYPE = 'CHAR' then

'String '

when c.DATA_TYPE = 'DATE' then

'Date '

when c.DATA_TYPE = 'NUMBER' then

'Integer '

when c.DATA_TYPE = 'BIGINT' then

'Long '

when c.DATA_TYPE = 'mediumtext' then

'String '

when c.DATA_TYPE = 'INT' then

'Long '

when c.DATA_TYPE = 'DATETIME' then

'LocalDateTime '

when c.DATA_TYPE = 'timestamp' then

'LocalDateTime '

when c.DATA_TYPE = 'DECIMAL' then

'BigDecimal '

when c.DATA_TYPE = 'ENUM' then

'String '

when c.DATA_TYPE = 'TEXT' then

'String '

when c.DATA_TYPE = 'MEDIUMINT' then

'Integer '

when c.DATA_TYPE = 'tinyint' then

'Integer '

when c.DATA_TYPE = 'FLOAT' then

'Float '

end), func_humpString(c.COLUMN_NAME,'_'),'; \n') as '属性信息' from information_schema.columns c

where c.TABLE_NAME = in_table

union

select '}' from dual;

CREATE FUNCTION `func_split`(f_string varchar(1000),f_delimiter varchar(5),f_order int) RETURNS varchar(255) CHARSET utf8

BEGIN

# 拆分传入的字符串,返回拆分后的新字符串

declare result varchar(255) default '';

set result = reverse(substring_index(reverse(substring_index(f_string,f_delimiter,f_order)),f_delimiter,1));

return result;

END

CREATE FUNCTION `func_split_TotalLength`(f_string varchar(1000),f_delimiter varchar(5)) RETURNS int(11)

BEGIN

# 计算传入字符串的总length

return 1+(length(f_string) - length(replace(f_string,f_delimiter,'')));

END

CREATE FUNCTION `func_humpString`(f_string varchar(1000),f_delimiter varchar(5)) RETURNS varchar(255) CHARSET utf8

BEGIN

declare cnt int default 0;

declare i int default 1;

declare result varchar(255) default '';

declare all_s varchar(255) default '';

set result = func_split(f_string,f_delimiter,i);

set cnt = func_split_TotalLength(f_string,f_delimiter);

while i < cnt

do

set i = i + 1;

set all_s = func_split(f_string,f_delimiter,i);

set result = concat(result,upper(left(all_s,1)),substring(all_s,2));

end while;

return result;

END

博客地址:http://blog.csdn.net/vipbooks 一直以来根据数据库表结构自动生成JavaBean、自动生成MyBaits的Mapper映射配置文件、自动生成数据库设计文档都是一件让人很头痛的事情,既浪费时间又很繁琐,看着几十上百个表的成千上万个字段,真是一件让人痛苦的事情。 我们也想过很多办法解决这个问题,包括用MyEclipse连接数据库生成JavaBean,但多多少少还是会有一些不尽人意的地方,包括表和表字段的comment总是无法生成,而且还会生成很多无用的注释代码,让代码看起来一点都不干净,配置非常繁琐等等问题。 于是一怒之下,自己动手丰衣足食,于是就自己用Swing写了一个基于数据库的自动化生成工具,支持MySQL、Oracle、SQLServce、PostgreSQL四种数据库,支持Window、Linux、MacBook等多个作系统,完美支持JPA注解,可以同时生成Entity和DTO等,可以自动去除表前缀,支持单个和批量生成JavaBean,现在不但成员变量上能生成备注了,而且在Getter和Setter上也能有注释了。更重要的是还能自动生成数据库设计文档和MyBaits的Mapper映射配置文件,如果有多个数据源还能批量生成,使用非常方便。 所有的配置都保存在本地,只要配置过一次,下次使用的时候完全可以秒生成JavaBean、MyBaits的Mapper映射配置文件和数据库设计文档,并且还集成各种实用工具,使得工作效率瞬间爆棚,生产力瞬间爆表! TableGo v5.8.0版更新震撼发布,此次版本更新如下: 1、新增自定义文件功能,可以自己编写模板生成任意代码的文件。 2、新增数据源配置自动生成功能,项目分库分表不用愁,一次搞定所有数据源。 3、公共参数界面新增表别名和是否目录直通的配置。 4、生成Bean界面新增是否生成字段注释和重写equals,hashCode,toString方法的配置。 5、MyBatis配置界面新增根据所有字段条件查询数据的选项。 6、新增TableGo使用说明书。 7、更新数据库驱动版本,新版的驱动可能不支持JDK8以下的版本。 8、修复了大量的Bug并进行了一些优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值