从Hibernate的映射谈编程思想

本文探讨了Hibernate作为对象关系映射框架的工作原理,重点解释了其基本规则和映射文件的构建方法。通过实体类和映射文件的实例演示,详细介绍了如何描述静态特性,并阐述了配置文件在Hibernate应用中的作用。最后,强调了除了实体类型和映射文件之外,还需要编写Java应用使用Hibernate API进行持久化操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

很多java工程师在作Hibernate应用开发时会遇到一些问题:我该写哪些东西?映射文件的XML元素我为什么记不住?等等。以下就这两个问题谈谈我的一些心得。

 

首先,学习任何一门新的框架首先要理解它所解决的问题域。Hibernate是一个解决对象关系映射的框架(ORM),这说明ORM必须遵循一定的规则,否则就不可能形成框架。ORM遵循的基本规则是什么呢?用这样四句话进行总结:

1. 类型(class)对应表(table);

2. 属性(property)对应列(column), 必须有特殊属性对象标识符(id)对应主键(primary key);

3. 类型的关联(association)关系对应外键(foreign key);

4.类型的实例即对象(object)对应记录(record)或行(row)。

前三项描述的是静态特性,映射文件主要描述的就是这三项静态特性。ORM技术O在前,当然映射文件应以其对应的类型(class)为中心进行描述。Gavin King在使用XML时喜欢用元素的属性来描述不具扩展前景的数据, 其中name属性描述java程序中JavaBean的属性(属性值大小写敏感)。映射文件的根元素用英文的mapping就可以了,但Gavin King不能脱俗,加上了hibernate的前缀让人们记住他。

 

有了以上的准则,加上我们学会了文章一开始就列出的几个英文单词,hibernate映射文件中常用的60%-70%已经印在了我们的脑袋。让我们用一个不包含关联关系的例子来验证:

实体类型Student:

package com.kettas.hibernate.entity;

import java.io.Serializable;

import java.util.Date;

 

public class Student implements Serializable{

       private Long id;

       private String name;

       private Date birthday;

       private char gender;

      

       public Student() {

              super();

       }

 

       public Student(String name, Date birthday, char gender) {

              super();

              this.name = name;

              this.birthday = birthday;

              this.gender = gender;

       }

 

       Date getBirthday() {

              return birthday;

       }

 

       void setBirthday(Date birthday) {

              this.birthday = birthday;

       }

 

       char getGender() {

              return gender;

       }

 

       void setGender(char gender) {

              this.gender = gender;

       }

 

       Long getId() {

              return id;

       }

 

       void setId(Long id) {

              this.id = id;

       }

 

       String getName() {

              return name;

       }

 

       void setName(String name) {

              this.name = name;

       }

      

 

 

}

 

映射文件:

<hibernate-mapping package=”com.kettas.hibernate.entity”>

   <!—类型对应表-->

   <class name=”Student” table=”STUDENTS”> 

              <!—id属性对应primary keyà

              <id name=”id” column=”STUDENTNO” unsaved-value=”null”>

       <generator class=”native”/>

</id>

<!—property对应列à

<property name=”name” column=”NAME”/>

<property name=”birthday” column=”BIRTHDAY”/>

<property name=”gender” column=”SEX”/>

   </class>

</hibernate-mapping>

 

除了generator(生成器)和unsaved-value外,我们没有看到更多的英文词汇。generator说明主键的生成算法,unsaved-value的值让hibernate能够判断对象是否为transient(瞬态)对象。

 

除了要写实体类型和映射文件,hibernate应用还需要写什么呢?当然必须有一个Java应用使用hibernate的API操作实体。这个应用知道操作哪些实体?如何和数据库通讯来完成持久化呢?通过配置文件就行了。所以配置文件里有描述连接数据库的属性和映射文件的元素。任何一本Hibernate的书都会提供如下hibernate架构图:

 

 

hibernate.cfg

.xml
 


这个图明确地告诉了作Hibernate的开发应该写什么东西。

更多的关于hibernate的议题留待随后的blog中。


本文来自优快云博客,转载请标明出处:http://blog.youkuaiyun.com/Kettas2008/archive/2008/06/24/2581637.aspx

内容概要:该研究通过在黑龙江省某示范村进行24小时实地测试,比较了燃煤炉具与自动/手动进料生物质炉具的污染物排放特征。结果显示,生物质炉具相比燃煤炉具显著降低了PM2.5、CO和SO2的排放(自动进料分别降低41.2%、54.3%、40.0%;手动进料降低35.3%、22.1%、20.0%),但NOx排放未降低甚至有所增加。研究还发现,经济性和便利性是影响生物质炉具推广的重要因素。该研究不仅提供了实际排放数据支持,还通过Python代码详细复现了排放特征比较、减排效果计算和结果可视化,进一步探讨了燃料性质、动态排放特征、碳平衡计算以及政策建议。 适合人群:从事环境科学研究的学者、政府环保部门工作人员、能源政策制定者、关注农村能源转型的社会人士。 使用场景及目标:①评估生物质炉具在农村地区的推广潜力;②为政策制定者提供科学依据,优化补贴政策;③帮助研究人员深入了解生物质炉具的排放特征和技术改进方向;④为企业研发更高效的生物质炉具提供参考。 其他说明:该研究通过大量数据分析和模拟,揭示了生物质炉具在实际应用中的优点和挑战,特别是NOx排放增加的问题。研究还提出了多项具体的技术改进方向和政策建议,如优化进料方式、提高热效率、建设本地颗粒厂等,为生物质炉具的广泛推广提供了可行路径。此外,研究还开发了一个智能政策建议生成系统,可以根据不同地区的特征定制化生成政策建议,为农村能源转型提供了有力支持。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值