Java反射机制实现Hibernate 二

配置好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();
		}
	}
	
}

 

你可能感兴趣的:(java,Hibernate,mysql,xml,jdbc)