首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > JAVA > Java Web开发 >

hibernate annotation多对一存储有关问题

2013-07-30 
hibernate annotation多对一存储问题我有两个类问题和问题类型。Question和QuestionType,一对多。Question表

hibernate annotation多对一存储问题
我有两个类问题和问题类型。Question和QuestionType,一对多。Question表里有QuestionType的外键,并且我想Questiontype是不能重复的,比如问卷类型就那几个,课堂反馈、网上调查等。所以在QuestionType的qt_des字段设置unique,我在savaquestion时就不能插入questionType了。
@Test
public void testQuestionsave1() {
Questions q = new Questions();
QuestionType qt = new QuestionType();
qt.setQt_des("单选");
q.setQ_head("你对于老师的教学方法感觉如何?");
q.setQ_body("非常棒&&不错&&一般&&不能理解");
q.setQ_number(4);
q.setQ_type(qt);
Session session = sf.openSession();
session.beginTransaction();

session.save(q);
//session.save(qt);
session.getTransaction().commit();
session.close();
}
测试第一遍时成功,测试第二遍时报错。
Hibernate: 
    insert 
    into
        QuestionType
        (qt_des) 
    values
        (?)
16:18:25,640  WARN JDBCExceptionReporter:100 - SQL Error: 1062, SQLState: 23000
16:18:25,641 ERROR JDBCExceptionReporter:101 - Duplicate entry '???é?‰' for key 'qt_des'。
我觉得应该是qt_des字段设置了unique,所以保存不了。但不知怎样处理,哪位大侠帮帮小弟?非常感谢 hibernate 多对一 保存 Hibernate
[解决办法]

引用:
@Test
 public void testQuestionsave1() {
 Questions q = new Questions();
 QuestionType qt = QuestionType.getQt_des("单选");
if(qt==null){
qt=new QuestionType();
         qt.setQt_des("多选");
}
q.setQ_head("你对于老师的教学方法感觉如何?");
q.setQ_body("非常棒&&不错&&一般&&不能理解");
q.setQ_number(4);
 q.setQ_type(qt);
 Session session = sf.openSession();
 session.beginTransaction();

 session.save(q);
 //session.save(qt);
 session.getTransaction().commit();
 session.close();
 }



写出这个参考链接http://zhidao.baidu.com/question/323570512.html

热点排行