spring通过注解方式hibernate映射文件
先看如下代码
1.这里要注意spring有几种加载映射文件的方式,我们以前遇到过的是通过
MappingResource来加载相应的映射xml文件,这次我们看看使用注解的方式来
加载映射文件。具体的注解映射方式可以参考
[url]http://blog.sina.com.cn/s/blog_5bd6b45101012ck5.html[/url]
2.此外除了通过注解的方式,我们也可以通过mappingDirectoryLocations属
性来定义映射文件。只要指出映射文件所在文件夹就可以了,Spring会替你找
出该文件夹内所有的映射文件,定义方法如下:
3.这里要理解下
category,它对应数据库表中名为category_id的字段,这样就使用这个字段来
作为外键关联,而不使用连接表了。
而在对应的“一”端,为
这是在多方的代码,增加一个连接表,名为board_adminstrator,在这个连接
表中,增加两个属性,一个属性为board_id,一个为person_id,分别对应这个
多对多表的两边的属性,而这里的InverseJoinColumns代表这个属性是“对方
”的一个属性。
多的另外一方,自然就是mapped到administrators
先看如下代码
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.annotation.AnnotationSessi
onFactoryBean"
destroy-method="destroy">
<property name="dataSource" ref="dataSource" />
<property name="annotatedClasses">
<list>
<value>com.helloweenvsfei.forum.bean.Category</value>
<value>com.helloweenvsfei.forum.bean.Board</value>
<value>com.helloweenvsfei.forum.bean.Thread</value>
<value>com.helloweenvsfei.forum.bean.Person</value>
<value>com.helloweenvsfei.forum.bean.Reply</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
org.hibernate.dialect.MySQLDialect
</prop>
<prop
key="hibernate.show_sql">true</prop>
<prop
key="hibernate.format_sql">false</prop>
<prop
key="hibernate.hbm2ddl.auto">update</prop>
</props>
</property>
</bean>
1.这里要注意spring有几种加载映射文件的方式,我们以前遇到过的是通过
MappingResource来加载相应的映射xml文件,这次我们看看使用注解的方式来
加载映射文件。具体的注解映射方式可以参考
[url]http://blog.sina.com.cn/s/blog_5bd6b45101012ck5.html[/url]
2.此外除了通过注解的方式,我们也可以通过mappingDirectoryLocations属
性来定义映射文件。只要指出映射文件所在文件夹就可以了,Spring会替你找
出该文件夹内所有的映射文件,定义方法如下:
<property name="mappingDirectoryLocations">
<list>
<value>WEB-INF/mappings</value>
</list>
</property>
具体可参见[url]http://blog.csdn.net/huiwenjie168/article/details/7013618[/url]
3.这里要理解下
@ManyToOne
@JoinColumn(name = "category_id")
private Category category;
的用法,这个为映射多对一,这里的JoinColumn的意思是加入一个新的属性
category,它对应数据库表中名为category_id的字段,这样就使用这个字段来
作为外键关联,而不使用连接表了。
而在对应的“一”端,为
@OneToMany(mappedBy = "category")
private List<Board> boards = new ArrayList<Board>();
4.我们再来理解下多对多
@ManyToMany(cascade = CascadeType.ALL)
@JoinTable(name = "board_administrator", joinColumns = {
@JoinColumn(name = "board_id") }, inverseJoinColumns = {
@JoinColumn(name = "person_id") })
private Set<Person> administrators = new HashSet<Person>();
这是在多方的代码,增加一个连接表,名为board_adminstrator,在这个连接
表中,增加两个属性,一个属性为board_id,一个为person_id,分别对应这个
多对多表的两边的属性,而这里的InverseJoinColumns代表这个属性是“对方
”的一个属性。
多的另外一方,自然就是mapped到administrators
@ManyToMany(mappedBy = "administrators")
private Set<Board> boardsAdministrated = new HashSet<Board>
();