对于bean对象自动生成数据库中对应的表结构,有很多强大的框架来帮我们完成。这里记录自己做的基于反射和注解方式自动生成数据库表的核心代码。
首先,是bean对象的配置文件,文件名为DAO.xml
<?xml version="1.0" encoding="UTF-8"?>
<packages>
<!-- DAO的所有包,这里可以将所有的bean配置在此 -->
<package-name>com.csl.student.vo</package-name>
</packages>
其次,对配置文件进行读取,类名为XMLReader。这里的解析用的DOM4j方式。
public class XMLReader {
private static SAXReader saxReader ;
private static Document document ;
// 初始化解析器和文档对象
static {
try {
// 解析器
saxReader = new SAXReader();
// 指定解析哪个xml文件
document = saxReader.read(new File("这里写XML文件的绝对路径"));
} catch (DocumentException e) {
e.printStackTrace();
}
}
//读取父节点下的所有package-name属性下的所有的值,保存到List集合中。
public static List<String> read() {
//声明集合
List<String> packages = new ArrayList<String>();
// 得到根元素
Element root = document.getRootElement();
// 取出 root元素 下的所有package-name元素
List<Element> packageNode= new ArrayList<Element>();
packageNode= root.elements("package-name");
for (int i = 0; i < packageNode.size(); i++) {
String packages_name = ((Element)packageNode.get(i)).getText();
packages.add(packages_name);
}
return packages;
}
}
然后,根据得到的bean的全名(包名和类名)利用注解和反射创建表。这里分为三个步骤:
第一,根据得到bean所在的包,扫描整个包,得到该包下所有的bean类。扫描包的抽象类为P