1.建立项目。java
2.下载官方jar包。hibernate-distribution-3.5.6-Finalapi
3.导入须要的包。app
D:\jar\hibernate\hibernate-distribution-3.5.6-Final\hibernate3.jar D:\jar\hibernate\hibernate-distribution-3.5.6-Final\lib\required\* D:\jar\hibernate\hibernate-distribution-3.5.6-Final\lib\jpa\hibernate-jpa-2.0-api-1.0.0.Final.jar
4.运行项目发现有错。框架
java.lang.NoClassDefFoundError: org/slf4j/impl/StaticLoggerBinder
导入另外一个包dom
D:\jar\slf4j-nop-1.5.8.jar
注意此时的包必须与 slf4j-api-1.5.8.jar 版本相对应。
fetch
对于外键关联,存在多个外键表实体对应一个主键表实体。在项目中就是一对多关联。例:ui
①汽车品牌表Brand对应的实体类:this
public class Brand { private int brandId; private String name; private int bIndex; private String memo; public int getBrandId() { return brandId; } public void setBrandId(int brandId) { this.brandId = brandId; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getbIndex() { return bIndex; } public void setbIndex(int bIndex) { this.bIndex = bIndex; } public String getMemo() { return memo; } public void setMemo(String memo) { this.memo = memo; } }
②汽车系列表Series对应的实体类:spa
public class Series { private int seriesId; private String name; private int sIndex; private String memo; private Brand brand; public int getSeriesId() { return seriesId; } public void setSeriesId(int seriesId) { this.seriesId = seriesId; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getsIndex() { return sIndex; } public void setsIndex(int sIndex) { this.sIndex = sIndex; } public String getMemo() { return memo; } public void setMemo(String memo) { this.memo = memo; } public Brand getBrand() { return brand; } public void setBrand(Brand brand) { this.brand = brand; } }
实际关系是一个品牌的汽车包含多个系列,所以存在多个系列从属于一个品牌的状况。故配置Series.hbm.xml以下:.net
<?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="com.server.doman"> <class name="Series"> <id name="seriesId" column="series_id" type="int"> <generator class="increment" /> </id> <!-- <property name="brandId" column="brand_id" type="int"></property> --> <property name="name" column="name" type="string"></property> <property name="sIndex" column="s_index" type="int"></property> <property name="memo" column="memo" type="string"></property> <!-- 多个系列可能从属于一个品牌 name对应Series类的brand属性,column对应Brand表的主键列--> <many-to-one name="brand" class="com.server.doman.Brand" column="Brand_id"/> </class> </hibernate-mapping>
注意:以上在Series类中有了brand类就不用添该表中的brand_id,不然就会报错
Column 'Brand_id' specified twice
列Brand_id 实例化两次。
3.1多对一
<set order-by="csid" name="categorySeconds" fetch="join"> <key column="cid"/> <one-to-many class="cn.itcast.shop.categorysecond.vo.CategorySecond"/> </set>
3.2一对多
<many-to-one name="category" fetch="join" class="cn.itcast.shop.category.vo.Category" column="cid"/>
3.3获取数据
String hql = "from Category"; List<Category> list = this.getHibernateTemplate().loadAll(Category.class);
总结:在映射文档中定义抓取策略时,只有经过get或load方法才生效。