Java逆向工程(数据库表生成java类)
说起来倒是挺简单的,就是听着名字感觉挺高大上。逆向工程方式有很多,比如mybatis就提供了一个这样的工具mybatis-genderator,这个我反正是没用过只是听说过,以前在公司都是用公司写好的的工具,最近也是闲的无聊自己动手写了一个。
我的这个工程师基于spring和mybatis写的,有兴趣的加上spring-mvc,加个页面也是不错的。
其实呢使用mybatis做逆向工程很简单就是两个select查询就好了,数据库底子好的童鞋们应该记得一下这两个查询语句的(不记得也没关系,可以学嘛):
1. 查询库中的所有表: select * from information_schema.TABLES where TABLE_SCHEMA=(select database())
2.查询表中的所有字段信息: select * from information_schema.COLUMNS where TABLE_SCHEMA = (select database()) and TABLE_NAME=#{tableName}
对于第一条sql来说查询那个库就连接哪个就行了,不需要传参数。但是第二条sql需要将表名传进去的(这也是无可厚非的)
必不可少的我们是需要数据库的4大连接参数,凡是和数据库挂钩应该都需要这几个玩意(这声明一下我这里是用的MySQL)。其他的配置文件上的事情我就不多说了。今天重点不在这里
接下来简单的将dao、service层贴出来了,和平时的web结构一样很简单。
service层
service实现类
接下来就是今天的重点了。其实也很简单,可能很多人都已经想到了,我们都已经获取到了表字段信息了,那么我们只需要一个文件流不就可以了?(嗯,没错,大兄弟,反正我就是这么写的)
其实我的这个很简单,主要围绕一个stringbuffer进行,先拼接到字符串中,然后用流写到文件中。下边我粘一下我的代码吧。
package com.ml.code.one.codegenerator.util; import com.ml.code.one.codegenerator.myservice.MyCodeService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component; import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.util.Iterator;
import java.util.List;
import java.util.Map; @Component
public class CodeGenerator {
@Autowired
private MyCodeService service; public void codeGenerator(String tableName,String path){
List<Map> columns = service.listColumn(tableName);//查询所有的表字段信息
String className = getClassName(tableName);
StringBuffer sb = new StringBuffer();
sb.append("package "+getPackageName(path)+";\n");
sb.append("import java.io.Serializable;"+"\n");
sb.append("import java.util.*;\n");
sb.append("import java.lang.*;\n");
sb.append("import lombok.Data;\n");
sb.append("import lombok.ToString;\n\n");
sb.append("@Data\n@ToString\n");
sb.append("public class "+className+" implements Serializable {\n");
sb.append("\tprivate static final long serialVersionUID = 1L;\n\n");
//获取字段信息
Iterator<Map> iterator = columns.iterator();
while (iterator.hasNext()){
Map next = iterator.next();
Object dataType = next.get("DATA_TYPE");//获取数据类型
String type = classCast(dataType);//数据类型
Object property = next.get("COLUMN_NAME");//获取字段名称
String propertity = getPropertity(property);//属性名称
Object annotation = next.get("COLUMN_COMMENT");//注解
sb.append("\tprivate "+type+" "+propertity+";"+"//"+(String)annotation+"\n");
}
sb.append("}");
//拼接结束 //生成文件
try {
//生成java文件
getFile(className,sb.toString(),path);
//生成mapper.xml
// getMapperFile(className,path);
} catch (IOException e) {
e.printStackTrace();
}
} /**
* 生成类名
* @param tableName 表名
* @return
*/
private String getClassName(String tableName){
String newClassName="";
int i = tableName.indexOf("_");
if (i<0){//没有下划线
newClassName = tableName.substring(0, 1).toUpperCase() + tableName.substring(1)+"Po";
}else{//有下划线
String[] strs = tableName.split("_");
StringBuffer sb = new StringBuffer();
for (int m = 0; m<strs.length; m++){
sb.append(strs[m].substring(0, 1).toUpperCase() + strs[m].substring(1));
}
newClassName=sb.toString()+"Po";
}
return newClassName;
}
//生成属性java类型
private String classCast(Object obj){
String type="";
String str=(String)obj;
if (str.equals("varchar")||str.equals("char")||str.equals("text")){
type="String";
}else if (str.equals("int")){
type="Integer";
}else if (str.equals("bigint")){
type="Long";
}else if (str.equals("double")||str.equals("float")){
type="Double";
}else if (str.equals("date")||str.equals("datetime")||str.equals("timestamp")){
type="Date";
}else {
type="String";
}
return type;
}
//数据库字段名字转java属性名字
private String getPropertity(Object obj){
String pro="";
String colum=(String)obj;
int index = colum.indexOf("_");//判断是否存在下划线
if (index<0){//没有下划线
pro=colum.substring(0,1).toLowerCase()+colum.substring(1);//首字母小写
}else {//有下划线
StringBuilder sb = new StringBuilder();
String[] colums = colum.split("_");
for (int i = 0; i<colums.length; i++){
if (i==0){
sb.append(colums[i].substring(0,1).toLowerCase()+colums[i].substring(1));//拼接第一个,并将首字母小写
}else{
sb.append(colums[i].substring(0,1).toUpperCase()+colums[i].substring(1));//除了第一个都将首字母大写
}
}
pro=sb.toString();
} return pro;
} /**
* 生成包名
*/
private String getPackageName(String path){
int index = path.indexOf("java\\");
String newPackage="";
if (index>0){
String substring = path.substring(index+5);
newPackage = substring.replace("\\", ".");
}
return newPackage;
} /**
* 生成文件
* @param fileName 文件名
* @param info 要写入的内容
* @throws IOException
*/
private void getFile(String fileName,String info,String path) throws IOException {
//生成文件
File file = new File(path+"\\"+fileName+".java");
if (!file.exists()){
file.createNewFile();
}
FileWriter writer = new FileWriter(file);
writer.write(info);
writer.flush();
writer.close();
} /**
* 生成Mapper.xml
* @param poName
*/
private void getMapperFile(String poName,String path) throws IOException {
//获取文件名
StringBuilder fileName = new StringBuilder();
int index = poName.indexOf("Po");
if (index<0){//没有Po后缀时
fileName.append(poName+"Mapper");
}else{//存在Po后缀
String sub = poName.substring(0, index);//截取到需要的部分
fileName.append(sub+"Mapper");
}
//获取路径
StringBuilder newPath = new StringBuilder();
int main = path.indexOf("main\\");
if (main>0){
String substring = path.substring(0, main+5);
newPath.append(substring).append("\\resources\\mapper\\");
} File file = new File(newPath+fileName.toString()+".xml");
StringBuilder xmlInfo = new StringBuilder();
xmlInfo.append("<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n");
xmlInfo.append("<!DOCTYPE mapper PUBLIC \"-//mybatis.org//DTD Mapper 3.0//EN\" \n" +
" \"http://mybatis.org/dtd/mybatis-3-mapper.dtd\">\n");
xmlInfo.append("<mapper namespace=\"\">\n");
xmlInfo.append("\n\n");
xmlInfo.append("</mapper>");
FileWriter fw = new FileWriter(file);
fw.write(xmlInfo.toString());
fw.flush();
fw.close();
}
}
这里我用的是boot工程写的,运行的时候我选择用boot自带的test工具运行就ok了(别忘了在启动类上加上dao层的包扫描呦)
到这里呢这个简单的逆向工程就结束了,这个可以直接生成到你指定文件下,顺带连Mapper.xml也生成了的。大佬勿喷。
有需要源码的可以到以下网盘获取,(网盘中的也只是一部分,只是逆向工程部分,其他的需要你们自行补充,应该是不难的)
补充一下,如果有用idea的我建议用idea的代码生成工具哈 下载一个插件就可以了 EasyCode,至于使用方法很简单,把你的idea连上数据库就好了,而且还可以手动配置呢
链接:https://pan.baidu.com/s/1KW7h9vro2U199hsL85Q38w
提取码:obpf
Java逆向工程(数据库表生成java类)的更多相关文章
- django根据已有数据库表生成model类
django根据已有数据库表生成model类 创建一个Django项目 django-admin startproject 'xxxx' 修改setting文件,在setting里面设置你要连接的数据 ...
- 如何通过java反射将数据库表生成实体类?
首先有几点声明: 1.代码是在别人的基础进行改写的: 2.大家有什么改进的意见可以告诉我,也可以自己改好共享给其他人: 3.刚刚毕业,水平有限,肯定有许多不足之处: 4.希望刚刚学习java的同学能有 ...
- JDBCUtils,根据当前MySQL数据库下面的表生成java实体类
自己简单写的JDBCUtils,可以根据当前数据库下面的表生成java实体类,代码萌新,请多多包涵. 初始化配置: //驱动程序名//不固定,根据驱动 static String driver = & ...
- Java 导出数据库表信息生成Word文档
一.前言 最近看见朋友写了一个导出数据库生成word文档的业务,感觉很有意思,研究了一下,这里也拿出来与大家分享一波~ 先来看看生成的word文档效果吧 下面我们也来一起简单的实现吧 二.Java 导 ...
- SqlServer数据库表生成C# Model实体类SQL语句——补充
在sql语句最前边加上 use[数据库名] 原链接:https://www.cnblogs.com/jhli/p/11552105.html --[SQL骚操作]SqlServer数据库表生成C ...
- J2EE进阶(十五)MyEclipse反向工程实现从数据库反向生成实体类之Hibernate方式
J2EE进阶(十五)MyEclipse反向工程实现从数据库反向生成实体类之Hibernate方式 反向工程又称逆向工程. 开发项目涉及到的表太多,一个一个的写JAVA实体类很是费事.MyEcl ...
- MyEclipse从数据库反向生成实体类之Hibernate方式 反向工程
前文: hibernate带给我们的O/RMapping思想是很正确的,即从面相对象的角度来设计工程中的实体对象,建立pojo,然后在编写hbm.xml映射文件来生成数据表.但是在实际开发中,往往我们 ...
- MyEclipse数据库反向生成实体类
MyEclipse数据库反向生成实体类 “计应134(实验班) 凌豪” 当我们在开发项目涉及到的表太多时,一个一个的写JAVA实体类很是费事.然而强大的MyEclipse为我们提供简便的方法:数据库反 ...
- 由数据库表生成jpa实体工具
package cn.net.yto.aaa.dao.generator; /** * 由数据库表生成jpa实体工具 * * @author huike * Created by gf.liu on ...
随机推荐
- Win10下 Java环境变量配置
安装java的JDK 下载地址 此电脑->属性->高级设置 "系统变量"新建 变量名:Java_Home 变量值:D:\Program Files\Java ...
- 学生信息的添加 Java web简单项目初试(失败)
题目要求: 1登录账号:要求由6到12位字母.数字.下划线组成,只有字母可以开头:(1分) 2登录密码:要求显示“• ”或“*”表示输入位数,密码要求八位以上字母.数字组成.(1分) 3性别:要求用单 ...
- nodejs(16)使用express.static快速托管静态资源
const express = require('express') const app = express() // 步骤的拆解 const result = express.static('./v ...
- 代码杂谈-SQL中的rank&row_number函数
两个函数细节记不住. 写个例子备注一下. select no, name, score , rank() over(partition by no order by score asc) rk1 , ...
- 201771010123汪慧和《面向对象程序设计JAVA》第九周实验总结
一.理论部分 1.异常 (1)异常处理的任务就是将控制权从错误产生的地方转移给能够处理这种情况的错误处理器. (2)程序中可能出现的错误和问题:a.用户输入错误.b.设备错误.c.物理限制.d.代码错 ...
- MySQL--SHOW ENGINE INNODB STATUS
===================================== -- :: 0x7f305b965700 INNODB MONITOR OUTPUT =================== ...
- iOS 蓝牙开发详解
目前iOS智能硬件的开发交互方式主要分为两种,一种是基于低功耗的蓝牙4.0技术(由于耗电低,也称作为BLE(Bluetooth Low Energy))对应iOS的框架为CoreBluetooth,另 ...
- ELK简单配置
input { file { path => ["/usr/local/kencery/tomcat/logs/catalina.out"] type => " ...
- UML-类图-如何画引用类和集合?
1.画引用类 引用到了类时,需要画关联线,否则其他基本类型(int.string.date等)不画. 2.画集合 当然,方法1中可加入箭头.对应java代码: public class Sale { ...
- 面向对象 part7 class
类的定义 类实际上是个“特殊的函数“,就像能够定义函数表达式和函数声明一样,类语法 有两个组成部分:类表达式和类声明式 类声明 类声明没有提升 静态方法 只有构造函数名可以调用,实例无法使用.常用于应 ...