mysql 表映射为java bean 手动生成。
在日常工作中,一般是先建表。后建类。
当然也有先UML构建类与类的层级关系,直接生成表。(建模)
这里只针对先有表后有类的情况。不采用代码生成器的情况。 例如:
原表结构:
假如这是我业务变动,添加的一个表,
同时我也要建对应的java类时。
一般我们是手动去复制。容易出错。而且也是体力活。这里面可以用SQL直接生成。 -- 创建存储 通过系统表解析出表的结构。然后把表结构拼接成java类。 CREATE PROCEDURE mypro(in tablename varchar(10),in dbo varchar(20))
BEGIN
declare colName varchar(100);
declare dataType varchar(100);
declare done int ;
declare temp varchar(100) default '';
declare `set` varchar(100) default '';
declare `get` varchar(100) default '';
declare resultTable cursor for select distinct column_name as name,data_type as type from information_schema.COLUMNS where table_name = tableName and table_SCHEMA = dbo;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done=1; DROP TABLE IF EXISTS temp;
create table temp(
`data` varchar(100),
`set` varchar(100),
`get` varchar(100)
)ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8; open resultTable;
posLoop:LOOP
FETCH resultTable into colName,dataType;
IF done=1 THEN
LEAVE posLoop;
END IF;
IF dataType='bigint' then
set temp = concat('private Integer ',colName,';');
set `set` = concat('public void set',UPPER(LEFT(colName,1)),RIGHT(colName,length(colName)-1),'(','Integer ',colName,'){ this.',colName,'=',colName,';','}');
set `get` = concat('public Integer get',UPPER(LEFT(colName,1)),RIGHT(colName,length(colName)-1),'(){ return ',colName,';','}');
ELSEIF dataType='varchar' then
set temp = concat('private String ',colName, ';');
set `set` = concat('public void set',UPPER(LEFT(colName,1)),RIGHT(colName,length(colName)-1),'(','String ',colName,'){ this.',colName,'=',colName,';','}');
set `get` = concat('public String get',UPPER(LEFT(colName,1)),RIGHT(colName,length(colName)-1),'(){ return ',colName,';','}');
ELSEIF dataType='int' then
set temp = concat('private Integer ',colName ,';');
set `set` = concat('public void set',UPPER(LEFT(colName,1)),RIGHT(colName,length(colName)-1),'(','Integer ',colName,'){ this.',colName,'=',colName,';','}');
set `get` = concat('public Integer get',UPPER(LEFT(colName,1)),RIGHT(colName,length(colName)-1),'(){ return ',colName,';','}');
ELSEIF dataType='date' then
set temp = concat('private Date ',colName ,';');
set `set` = concat('public void set',UPPER(LEFT(colName,1)),RIGHT(colName,length(colName)-1),'(','Date ',colName,'){ this.',colName,'=',colName,';','}');
set `get` = concat('public Date get',UPPER(LEFT(colName,1)),RIGHT(colName,length(colName)-1),'(){ return ',colName,';','}');
ELSEIF dataType='datetime' then
set temp = concat('private Date ',colName ,';');
set `set` = concat('public void set',UPPER(LEFT(colName,1)),RIGHT(colName,length(colName)-1),'(','Date ',colName,'){ this.',colName,'=',colName,';','}');
set `get` = concat('public Date get',UPPER(LEFT(colName,1)),RIGHT(colName,length(colName)-1),'(){ return ',colName,';','}');
ELSEIF dataType='decimal' then
set temp = concat('private BigDecimal ',colName ,';');
set `set` = concat('public void set',UPPER(LEFT(colName,1)),RIGHT(colName,length(colName)-1),'(','BigDecimal ',colName,'){ this.',colName,'=',colName,';','}');
set `get` = concat('public BigDecimal get',UPPER(LEFT(colName,1)),RIGHT(colName,length(colName)-1),'(){ return ',colName,';','}');
ELSEIF dataType='char' then
set temp = concat('private String ',colName ,';');
set `set` = concat('public void set',UPPER(LEFT(colName,1)),RIGHT(colName,length(colName)-1),'(','String ',colName,'){ this.',colName,'=',colName,';','}');
set `get` = concat('public String get',UPPER(LEFT(colName,1)),RIGHT(colName,length(colName)-1),'(){ return ',colName,';','}');
ELSEIF dataType='text' then
set temp = concat('private String ',colName ,';');
set `set` = concat('public void set',UPPER(LEFT(colName,1)),RIGHT(colName,length(colName)-1),'(','String ',colName,'){ this.',colName,'=',colName,';','}');
set `get` = concat('public String get',UPPER(LEFT(colName,1)),RIGHT(colName,length(colName)-1),'(){ return ',colName,';','}');
END IF ;
insert into temp(`data`,`set`,`get`) values(temp,`set`,`get`);
END LOOP posLoop;
CLOSE resultTable;
END;
call mypro('person','test'); //第一个参数是表名,针对表名生成java类结构。第二个参数是dbo指定的哪个数据库
select * from temp;
效果图:

实际应用:
直接复制就行了。

结果:

完全正常, 这样就不用一个个去手动建java类了。
里面的toString() 跟类名 没有去自动生动。手动写一下就OK。这样就方便好了。
MYsql不支持print打印 只能select 所以就插入到表中了。
如果用mssql 就直接print 配合 CHAR(10),CHAR(13) 能直接生成一个完整的java bean 包括 toString() 方法 类名。mysql有一定的局限性。
如果这里是采用mybaits的话。
手动去复制表结构是很累人的。也容易出错。mybatis insert into tb(col1,col2) value(#{value1},#{value2});
这里面如果也需要手动复制的话。也有相应的SQL语句,参见,另一篇博客:https://www.cnblogs.com/1-Admin/p/8447052.html
END
mysql 表映射为java bean 手动生成。的更多相关文章
- EJB_开发单表映射的实体bean
开发单表映射的实体bean 实体bean 它属于java持久化规范(JPA)里的技术,实体bean通过元数据在Javabean和数据库表之间建立起映射关系,然后Java程序员就可以随心所欲的使用面向对 ...
- 高速创建和mysql表相应的java domain实体类
今天创建了一个表有十几个字段,创建完之后必定要写一个与之相应的java domain实体类. 这不是反复的工作吗?为什么不先把这个表的全部的字段查出来,然后放到linux环境下,用sed工具在每一行的 ...
- mysql表生成JavaBean
MySQLToBean.java package org.just.util; import java.io.File; import java.io.FileInputStream; import ...
- java基础复习-自定义注解4(结合JDBC技术,打造类表映射微框架)
写在前面: 1.该框架为自己所写的第一个框架类产品,可能有着许多不足的地方,读者可以到评论区指出.同时,该微框架的源码也会开源至博客中,够后来的学习者借鉴.由于该框架逻辑结构稍些复杂,不可能花大量篇幅 ...
- Hibernate 表映射 主键生成策略与复合主键
主要分析三点: 一.数据表和Java类的映射 : 二.单一主键映射和主键的生成策略 : 三.复合主键的表映射 : 一.数据表和Java类的映射 Hibernate封装了数据库DDL语句,只需要将数据 ...
- 通过数据库中的表,使用 MyEclipse2017的反向生成工具-->hibernate反转引擎引擎(MyEclipse2017自带的插件) 来反转生成实体类和对应的映射文件
通过数据库中的表,使用 MyEclipse2017的反向生成工具-->hibernate反转引擎引擎(MyEclipse2017自带的插件) 来反转生成实体类和对应的映射文件 文章目录 Ja ...
- Mysql,Oracle与Java字段类型映射关系
Mysql,Oracle与Java字段类型映射关系 参考相关博文 MySQL/Oracle字段类型 Java字段类型 最大长度 BIT java.lang.Boolean 1 BLOB java.la ...
- 使用maven根据JSON文件自动生成Java POJO类(Java Bean)源文件
根据JSON文件自动生成Java POJO类(Java Bean)源文件 本文介绍使用程序jsonschema2pojo来自动生成Java的POJO类源文件,本文主要使用maven,其他构建工具请参考 ...
- java面试题之----mysql表优化方案
本文转载自segmentfault,原文链接:https://segmentfault.com/a/1190000006158186. 当MySQL单表记录数过大时,增删改查性能都会急剧下降,可以参考 ...
随机推荐
- 第一份offer
11月6日参加的面试,今天签完三方,回头想想,感慨万千. (很多过程没有详细写,只保留了基本的客观事实,避免自吹嫌疑.....) 6号面试,当时来了能有100-200人,以川大和电子科大研究生为主,主 ...
- dede织梦判断导航栏是否有子栏目
以下代码判断导航栏是否含有子栏目 {dede:field name=typeid runphp="yes"} global $dsql; $sql , "; $row = ...
- nginx搭建以及其配置文件
nginx搭建: 参考link:https://blog.csdn.net/wxyjuly/article/details/79443432 nginx配置文件详解: 参考link:https://w ...
- Mad Libs游戏:熟悉python编程环境,基本输入输出
Mad Libs游戏: 代码: name1=input("请输入一个名字:") name2=input("请输入一个名字:") print("{}才刚 ...
- 2.2使用urllib的简单传输
使用urllib传输文件 from urllib.request import urlopen filename = 'new_1.py' password = 'password' #如果设置密码 ...
- Vxlan基础理解
一 . 为什么需要Vxlan 1. vlan的数量限制 4096个vlan远不能满足大规模云计算数据中心的需求 2. 物理网络基础设施的限制 基于IP子网的区域划分限制了需要二层网 ...
- [转]keepalived简介
https://www.jianshu.com/p/b050d8861fc1 contents: 什么是Keepalived VRRP协议简介 Keepalived原理 Keepalived配置文件详 ...
- sql语言 含有包含关系的查询 (含mysql 和sql sever)
一.sql中查询包含关系的查询 sql语句中包含关系可以使用 in 和exist,但有些时候仅仅用这两个是不够的,还有表示方法是 not exist(b expect a )可以表示a包含b. 二. ...
- 学习笔记TF047:PlayGround、TensorBoard
PlayGround.http://playground.tensorflow.org .教学目的简单神经网络在线演示.实验图形化平台.可视化神经网络训练过程.在浏览器训练神经网络.界面,数据(DAT ...
- error: invalid use of void expression
void*类型定义的指针变量只可以接收对象的地址,而没有对象类型这个概念.所以void*指针变量是不能直接用“*指针变量”去访问,需要强制类型转换后才能“间接”访问: *(type*)指针变量,必须给 ...
假如这是我业务变动,添加的一个表,