Java代码实体类生成SQL语句(Java实体类转数据库)

Java代码实体类生成SQL语句(Java实体类转数据库)有的时候把数据库删了,如果照着实体类重新创建数据库的话比较麻烦,可以使用这个工具,把代码复制到项目里面设置一下即可把Java代码中的实体类转换为SQL语句输出为一个文件,打开执行命令即可。代码如下:packageMain;importjavax.xml.bind.annotation.XmlElement;importjava.io.*;importjava.lang.annotation.Annotation;importjava.lang.reflect.Field;p.

大家好,又见面了,我是你们的朋友全栈君。

有的时候把数据删了,如果照着实体类重新创建数据库的话比较麻烦,可以使用这个工具,把代码复制到项目里面设置一下即可把Java代码中的实体类转换为SQL语句输出为一个文件,打开执行命令即可。

下载:https://download.csdn.net/download/weixin_44893902/20367422
在这里插入图片描述

代码如下:

package Main;

import javax.xml.bind.annotation.XmlElement;
import java.io.*;
import java.lang.annotation.Annotation;
import java.lang.reflect.Field;

public class GenerateSqlFromEntityUtil { 
   

	public static void main(String[] a) { 
   
		// 实体类的位置
		Class klass = cn.ac.azure.model.User.class;
		// 生成的sql语句的位置
		String outputPath = "D:/outSql/User.txt";
		generateTableSql(klass, outputPath, null);
		System.out.println("生成结束");
	}

	public static void writeFile(String content, String outputPath) { 
   
		File file = new File(outputPath);
		System.out.println("文件路径: " + file.getAbsolutePath());
		// 输出文件的路径
		if (!file.getParentFile().exists()) { 
   
			file.getParentFile().mkdirs();
		}
		FileOutputStream fos = null;
		OutputStreamWriter osw = null;
		BufferedWriter out = null;

		try { 
   
			// 如果文件存在,就删除
			if (file.exists()) { 
   
				file.delete();
			}
			file.createNewFile();
			fos = new FileOutputStream(file, true);
			osw = new OutputStreamWriter(fos);
			out = new BufferedWriter(osw);
			out.write(content);
			// 清空缓冲流,把缓冲流里的文本数据写入到目标文件里
			out.flush();
		} catch (FileNotFoundException e) { 
   
			e.printStackTrace();
		} catch (IOException e) { 
   
			e.printStackTrace();
		} finally { 
   
			try { 
   
				fos.close();
			} catch (IOException e) { 
   
				e.printStackTrace();
			}

			try { 
   
				osw.close();
			} catch (IOException e) { 
   
				e.printStackTrace();
			}

			try { 
   
				out.close();
			} catch (IOException e) { 
   
				e.printStackTrace();
			}
		}
	}

	public static void generateTableSql(Class obj, String outputPath, String tableName) { 
   
		// tableName 如果是 null,就用类名做表名
		if (tableName == null || tableName.equals("")) { 
   
			tableName = obj.getName();
			tableName = tableName.substring(tableName.lastIndexOf(".") + 1);
		}
		// 表名用大写字母
		tableName = tableName.toUpperCase();

		Field[] fields = obj.getDeclaredFields();
		Object param;
		String column;

		StringBuilder sb = new StringBuilder();

		sb.append("drop table if exists ").append(tableName).append(";\r\n");

		sb.append("\r\n");

		sb.append("create table ").append(tableName).append("(\r\n");

		System.out.println(tableName);

		boolean firstId = true;

		for (int i = 0; i < fields.length; i++) { 
   
			Field f = fields[i];

			column = f.getName();

			System.out.println(column + ", " + f.getType().getSimpleName());

			param = f.getType();
			sb.append(column); // 一般第一个是主键

			if (param instanceof Integer) { 
   
				sb.append(" INTEGER ");
			} else { 
   
				// 注意:根据需要,自行修改 varchar 的长度。这里设定为长度等于 50
				int length = 50;
				sb.append(" VARCHAR(" + length + ")");
			}

			if (firstId == true) { 
   
				sb.append(" PRIMARY KEY ");
				firstId = false;
			}

			// 获取字段中包含 fieldMeta 的注解

			// 获取属性的所有注释
			Annotation[] allAnnotations = f.getAnnotations();

			XmlElement xmlElement = null;
			Class annotationType = null;

			for (Annotation an : allAnnotations) { 
   
				sb.append(" COMMIT '");
				xmlElement = (XmlElement) an;
				annotationType = an.annotationType();
				param = ((XmlElement) an).name();
				System.out.println("属性 " + f.getName() + " ----- 的注释类型有: " + param);
				sb.append(param).append("'");
			}

			if (i != fields.length - 1) { 
    // 最后一个属性后面不加逗号
				sb.append(", ");
			}

			sb.append("\n");
		}

		String sql = sb.toString();

		sql = sb.substring(0, sql.length() - 1) + "\n) " + "ENGINE = INNODB DEFAULT CHARSET = utf8;";

		writeFile(sql, outputPath);
	}
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/137938.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 面试框架题整理

    面试框架题整理面试题总结一基础部分1.1集合1.1.1fail-fast与fail-safe机制有什么区别1.1.2说出ArrayList,Vector,LinkedList的存储性能和特性ArrayList采用的是数组形式来保存对象的,这种方式将对象放在连续的位置中,所以最大的缺点就是插入删除时非常麻烦LinkedList采用的将对象存放在独立的空间中,而且在每个空间中还保存下一个链接的索引但是缺点就是查找非常麻烦要丛第一个索引开始ArrayList和Vector都是用数组方

    2022年5月11日
    24
  • jmespath(2)投影Projections「建议收藏」

    jmespath(2)投影Projections「建议收藏」投影投影是JMESPath的关键特性之一。它允许您将表达式应用于元素集合。有五种投影:列表投影切片投影对象投影展平投影过滤投影处理投影需要注意的点投影分为两个步骤。左侧(LHS)创建一

    2022年8月6日
    5
  • Telerik的RadControls控件(二)

    Telerik的RadControls控件(二)继上篇我们学习了RadWindow控件的用法之后,本篇我们将学习在项目中更加方便开发人员的常用控件RadAjax控件.  RadAjax是面向ASP.NET应用程序无编码AJAX使能化的第一个框架。这个专利Click-and-Go™技术可以让你不需要对你应用程序做任何修改(摆放Callback面板,设置触发器等)。最棒的是,你根本不需要写一行的JavaScript或s

    2022年7月24日
    5
  • 怎样用python开发安卓app_python开发app可以商用嘛

    怎样用python开发安卓app_python开发app可以商用嘛显然,时下最流行的信息学技术就是深度学习了。深度学习(DeepLearning,DL)或阶层学习(hierarchicallearning)是机器学习的技术和研究领域之一,通过建立具有阶层结构的人工神经网络(ArtifitialNeuralNetworks,ANNs),在计算系统中实现人工智能。由于阶层ANN能够对输入信息进行逐层提取和筛选,因此深度学习具有表征学习(representat…

    2022年8月12日
    5
  • vs2017当前页面的脚本发生错误_win10当前页面脚本发生错误

    vs2017当前页面的脚本发生错误_win10当前页面脚本发生错误今天使用金山卫士对IE8进行组件升级,此后再此使用VS2008查看项目界面中的控件变量类型,或者添加变量,都弹出“当前页面脚本错误”。在网上进行查找。解决办法如下:1、进入到注册表编辑器。2、按照以下路径“HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Internet  Settings\Zones”查看是否存在

    2022年8月30日
    1
  • Kibana介绍、安装和使用「建议收藏」

    Kibana介绍、安装和使用「建议收藏」ES之Kibana下面就Kibana对ES的查询监控作介绍,就是常提到的大数据日志处理组件ELK里的K。  什么是Kibana?现引用园友的一段对此的介绍,个人觉得比较全。  Kibana是一个针对Elasticsearch的开源分析及可视化平台,用来搜索、查看交互存储在Elasticsearch索引中的数据。使用Kibana,可以通过各种图表进行高级数据分析及展示。  Kibana让海量数据更容…

    2022年6月11日
    94

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号