配置好JDBC之后,要读取pojo类的配置文件
例如:
Userinfo.hbm.xml
<hibernate-mapping> <!-- 指定类到表的映射 --> <class name="tw.blog.pojo.Userinfo" table="userinfo"> <!-- 主键id的生成机制:native将自动根据数据库生成,mysql是自增长方式 --> <id name="id" column="id"> <generator class="mysql" /> </id> <!-- 设定Userinfo类中每个属性到userinfo表中对应列名的映射 --> <property name="name" column="name" /> <property name="pwd" column="pwd" /> <property name="age" column="age" /> </class> </hibernate-mapping>
要读取的信息包括类名及对应的文件名、主键的属性名和数据库中的列名、主键的生成机制、其他属性名和对应的数据库列名。
将信息存储在PojoXml对象中
PojoXml
public class PojoXml {
/** 类名 **/
private String classname;
/** 表名 **/
private String tablename;
/** 主键 **/
private String key;
/** 是否自动增长 1 自增长 0 本地设置**/
private int key_auto;
/** 类属性队列 **/
private List<String> nameList=new ArrayList();
/** 表列队列 **/
private List<String> columnList=new ArrayList();
PojoXmlReader
是用来将制定xml文件信息读取到PojoXml对象中的类
public class PojoXmlReader{
/** XML配置 **/
private PojoXml pojo;
/** XML文件路径 **/
private String url;
/**
* 将XML中的配置读取到XML配置对象中
* @param pojo 要存入的XML配置对象
* @param url XML文件的绝对路径
*/
public PojoXmlReader(PojoXml pojo,String url) {
this.pojo = pojo;
this.url=url;
}
/**
* 读取XML配置
*/
public void read(){
try {
//得到XML文件的Document对象
Document doc=new DocumentReader().read(url);
//取得根节点
Element root=doc.getRootElement();
//取得Class节点
Element element=root.element("class");
//设置类名
pojo.setClassname(element.attributeValue("name"));
//设置表名
pojo.setTablename(element.attributeValue("table"));
//设置主键
pojo.setKey(element.element("id").attribute(0).getData().toString());
//读取主键生成机制
String key=element.element("id").element("generator").attribute(0).getValue();
if(key.equals("mysql"))
pojo.setKey_auto(1);
else if(key.equals("native"))
pojo.setKey_auto(0);
//设置主键的类型和表中对应的类型
pojo.getNameList().add(element.element("id").attribute(0).getData().toString());
pojo.getColumnList().add(element.element("id").attribute(1).getData().toString());
//遍历属性的类型和表中对应的类型
for(Iterator i=element.elementIterator();i.hasNext();){
element=(Element)i.next();
if(element.getName().equals("property")){
pojo.getNameList().add(element.attribute(0).getData().toString());
pojo.getColumnList().add(element.attribute(1).getData().toString());
}
}
} catch (DocumentException e) {
e.printStackTrace();
}
}
}