spring经过注解方式hibernate映射文件
spring通过注解方式hibernate映射文件
spring通过注解方式hibernate映射文件
先看如下代码
1.这里要注意spring有几种加载映射文件的方式,我们以前遇到过的是通过
MappingResource来加载相应的映射xml文件,这次我们看看使用注解的方式来
加载映射文件。具体的注解映射方式可以参考
http://blog.sina.com.cn/s/blog_5bd6b45101012ck5.html
2.此外除了通过注解的方式,我们也可以通过mappingDirectoryLocations属
性来定义映射文件。只要指出映射文件所在文件夹就可以了,Spring会替你找
出该文件夹内所有的映射文件,定义方法如下:
3.这里要理解下
category,它对应数据库表中名为category_id的字段,这样就使用这个字段来
作为外键关联,而不使用连接表了。
而在对应的“一”端,为
这是在多方的代码,增加一个连接表,名为board_adminstrator,在这个连接
表中,增加两个属性,一个属性为board_id,一个为person_id,分别对应这个
多对多表的两边的属性,而这里的InverseJoinColumns代表这个属性是“对方
”的一个属性。
多的另外一方,自然就是mapped到administrators
spring通过注解方式hibernate映射文件
先看如下代码
<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文件,这次我们看看使用注解的方式来
加载映射文件。具体的注解映射方式可以参考
http://blog.sina.com.cn/s/blog_5bd6b45101012ck5.html
2.此外除了通过注解的方式,我们也可以通过mappingDirectoryLocations属
性来定义映射文件。只要指出映射文件所在文件夹就可以了,Spring会替你找
出该文件夹内所有的映射文件,定义方法如下:
<property name="mappingDirectoryLocations"> <list> <value>WEB-INF/mappings</value> </list> </property>具体可参见http://blog.****.net/huiwenjie168/article/details/7013618
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> ();