论坛首页 Java企业应用论坛

hibernate入门篇之新增功能_3:one-to-many

浏览 37655 次
该帖已经被评为精华帖
作者 正文
   发表时间:2003-12-24  
接上一篇文章hibernate入门篇之新增功能_2:one-to-one。我们再继续进行!(为什么要说再呢?)
Publication.java
package com.javamodel.hibernate;

public class Publication {
	
	private String id = null;
	private String bookName = null;
	private String dataTime = null;
	private String authorId = null;
	private Author author = null;
	
	public Publication();{}
	
	/**
	 * @return
	 */
	public String getBookName(); {
		return bookName;
	}

	/**
	 * @return
	 */
	public String getDataTime(); {
		return dataTime;
	}

	/**
	 * @return
	 */
	public String getId(); {
		return id;
	}

	/**
	 * @param string
	 */
	public void setBookName(String string); {
		bookName = string;
	}

	/**
	 * @param string
	 */
	public void setDataTime(String string); {
		dataTime = string;
	}

	/**
	 * @param string
	 */
	public void setId(String string); {
		id = string;
	}

	/**
	 * @return
	 */
	public String getAuthorId(); {
		return authorId;
	}

	/**
	 * @param string
	 */
	public void setAuthorId(String string); {
		authorId = string;
	}

	/**
	 * @return
	 */
	public Author getAuthor(); {
		return author;
	}

	/**
	 * @param author
	 */
	public void setAuthor(Author author); {
		this.author = author;
	}

}

Publication.hbm.xml
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping SYSTEM "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd" >
<hibernate-mapping>
	<class name="com.javamodel.hibernate.Publication" table="publication">
		<id name="id" column="id">
			<generator class="uuid.hex"/>
		</id>
		<property name="bookName" column="bookname" />
		<property name="dataTime" column="datatime" />
		
		<many-to-one name="author" column="authorid" />
	</class>
</hibernate-mapping>

Author.java加上
private Set publications = new HashSet();;//add get,set

author.hbm.xml加上

		<set name="publications" lazy="true" inverse="true" cascade="all" >
		  <key column="authorid"/> 
		  <one-to-many class="com.javamodel.hibernate.Publication" />
		</set>

Example.java
package com.javamodel.hibernate;

import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;

import net.sf.hibernate.HibernateException;
import net.sf.hibernate.MappingException;
import net.sf.hibernate.Session;
import net.sf.hibernate.SessionFactory;
import net.sf.hibernate.Transaction;
import net.sf.hibernate.cfg.Configuration;


public class Example{
	
	private static SessionFactory _sessions = null;
	private static Properties pops = new Properties();;
	
	static{
		try {
			InputStream stream = Example.class.getResourceAsStream("hibernate.properties");;
			try {
				pops.load(stream);;
			} catch (IOException e1); {
				e1.printStackTrace();;
			}
			
			Configuration cfg = new Configuration();;
			cfg.addClass(Person.class);;
			cfg.addClass(Author.class);;
			cfg.addClass(Publication.class);;
			cfg.setProperties(pops);;
			_sessions = cfg.buildSessionFactory();;
			
	    } catch (MappingException e); {
		   e.printStackTrace();;
	    } catch (HibernateException e); {
		   e.printStackTrace();;
	    }
	
	}
	
	public static void main(String[] args); throws HibernateException {
		
		Person person = new Person();;
		
		person.setName("HengfeiDo");;
		person.setEmail("smallduzi@sohu.com");;
		
		Publication publication1 = new Publication();;
		publication1.setBookName("AAA");;
		publication1.setDataTime("20031224");;
		Publication publication2 = new Publication();;
		publication2.setBookName("BBB");;
		publication2.setDataTime("20031225");;
		
		Author author = new Author();;

		author.setAlias("smallduzi");;
		author.setPerson(person);;
		author.getPublications();.add(publication1);;
		author.getPublications();.add(publication2);;
		
		publication1.setAuthor(author);;
		publication2.setAuthor(author);;

		Session session = _sessions.openSession();;
		
		Transaction tx = null;
		try{
			tx = session.beginTransaction();;
			session.save(author);;
			
			tx.commit();;
			System.out.println("over");;
		}catch(HibernateException he);{
			if(tx != null); tx.rollback();;
			throw he;
		}
		finally{
			session.close();;
		}
		
	}
	
}

下一篇,我们介绍many-to-many
   发表时间:2003-12-24  
如果转载,请注明:中国Hibernate技术专业论坛。
一经发现打50大板。
0 请登录后投票
   发表时间:2003-12-25  
其他不需要save();
这几个例子,经过本人的严格测试。放心不会误人子弟的。
耐心的是一下吧。
0 请登录后投票
   发表时间:2003-12-29  
这个例子我有一些问题呢,执行后,我检查publication这个table,里头没有资料呢。
(我用 select * from publication;他说empty set)

不过我加入
session.save(publication1);
session.save(publication2);
之后,才可以在资料库找此2笔资料呢。

我本身是用MySQL的,不知道是否这个问题呢??

我把 private Set publications = new HashSet(); 加在前面。
private String id ;
private String alias = null;
private Person person = null;
private Set publications = new HashSet();

然后在后面加入
public void setPublications(Set publications) {
  this.publications=publications;
}

public Set getPublications() {
  return publications;
}

不知道是哪里出错了呢。 因为 smallduzi 兄说其它的不必save()呢。
0 请登录后投票
   发表时间:2004-01-07  
&lt;set name="publications" lazy="true" inverse="true" cascade="all" &gt;
        &lt;key column="authorid"/&gt;
        &lt;one-to-many class="com.javamodel.hibernate.Publication" /&gt;
      &lt;/set&gt;
请各位解释一下上面!:)还有下面也一起!
         InputStream stream = Example.class.getResourceAsStream("hibernate.properties");
            pops.load(stream);
谢了
0 请登录后投票
   发表时间:2004-01-08  
我的也是这个问题,只有一个表有数据,其他的表都没有数据,请作者解释一下
0 请登录后投票
   发表时间:2004-01-09  
解释什么呢?:)
0 请登录后投票
   发表时间:2004-01-10  
ft,我更郁闷,我one的那个婊insert成功了,many那个表应该有2条的,不知道为什么只有1条
0 请登录后投票
   发表时间:2004-01-12  
回应 smallduzi 兄,就是您说说的,“其它的不必save()”,我也发问了。
如果其他的我没有save()的话,那么纪录里头是empty set, (我用select * from XX检查),必须把所有东西都save()才可以把资料save到database里头。
不知道是不是database不同的关系。
0 请登录后投票
   发表时间:2004-01-13  
我自己做的一个one to many例子中,查询没有问题,也是保存有问题。

如果只保存一个对象,关联的对象是没有保存的。

请楼主解惑帮忙,分析可能会出现这种问题的原因。

谢谢!期待中呀!
0 请登录后投票
论坛首页 Java企业应用版

跳转论坛:
Global site tag (gtag.js) - Google Analytics