原因:该关联关系的属性在多的一方的表中,这说明关联关系由多的一方来维护,在维护关联关系的时候在多的一方容易维护,主要还是看关联关系的属性在哪一方,由主动方负责维护关联关系,当在对象关系中删除一个book时,同时也必须由一方来维护关系,关联关系中。
关于hibernate的经典书籍
推荐Hibernate实战(第2版)【作 者】(德)Christian Bauer;(澳)Gavin King【译 者】 杨春花;彭永康;俞黎敏 【出 版 社】 人民邮电出版社【出版日期】 2008 年4月Hibernate之父Gavin King亲自执笔,深入剖析了Hibernate 3.2和Java Persistence丰富的编程模型,还深刻阐述了数据库设计、对象/关系映射(ORM)和优化等方面的基本原则、策略和最佳实践。
hibernate里的inverse和cascade是什么区别
这两个属性都用于一多对或者多对多的关系中。而inverse特别是用于双向关系,在单向关系中我们并不需要。 Cascade代表是否执行级联操作,Inverse代表是否由己方维护关系。 Cascade: Cascade属性的可能值有 all: 所有情况下均进行关联操作,即save-update和delete。 none: 所有情况下均不进行关联操作。这是默认值。 save-update: 在执行save/update/saveOrUpdate时进行关联操作。 delete: 在执行delete 时进行关联操作。 all-delete-orphan: 当一个节点在对象图中成为孤儿节点时,删除该节点。比如在一个一对多的关系中,Student包含多个book,当在对象关系中删除一个book时,此book即成为孤儿节点。 Inverse: Inverse属性的可能值是true或者false,默认为false: false代表由己方来维护关系,true代表由对方来维护关系。在一个关系中,只能由一方来维护关系,否则会出问题(解疑中会讲到);同时也必须由一方来维护关系,否则会出现双方互相推卸责任,谁也不管。 1、cascade(级联) 引用了《深入浅出 Hibernate》:级联(cascade)在Hibernate映射关系中,它指的是当主控方执行操作时,关联对象(被动方)是否同步执行同一操作,如主控方对象调用save-update或delete 方法时,是否同事对关联对象(被动方)进行save-update或delete。 这里所说的主控方按我理解指的是:比如,User 类中有一Address属性,User和Address 是一对多的关系,然后当user.save(address);的时候,user就是主控方了。 2、inverse(控制方向反转) 引用了《深入浅出 Hibernate》:在Hibernate 语义中,inverse指定了关联关系中的方向。关联关系中,inverse=false 的为主动方,由主动方负责维护关联关系。 这里所说的关联关系按我理解指的是:为了维持两个实体类(表)的关系,而添加的一些属性,该属性可能在两个实体类(表)或者在一个独立的表里面,这个要看这双方直接的对应关系了: ps:这里的维护指的是当主控放进行增删改查操作时,会同时对关联关系进行对应的更新。 一对多:该属性在多的一方。应该在一方的设置 inverse=true ,多的一方设置 inverse=false(多的一方也可以不设置inverse属性,因为默认值是false),这说明关联关系由多的一方来维护。原因:该关联关系的属性在多的一方的表中,在维护关联关系的时候在多的一方容易维护。 多对多:属性在独立表中。在任意一方设置inverse=true,另一方inverse=false;原因:如果两个多设置为true 的话,表示两方都对关联关系表(独立表)进行了同样的维护,其实只要一方维护就行了,效率上来说,这样设置是合理点的。 一对一:其实是一对多的一个特例,inverse 的设置也是一样的,主要还是看关联关系的属性在哪一方,这一方的inverse=false。 多对一:也就是一对多的反过来,没什么区别。
关于SSH,请大家推荐几本书
你可以看看蔡卫琴的这些方面的书,她的书相当还是比较基础的,如果要深层次了解的话,那有时间你可以看他们的源代码,反正是开源的,记得看过struts的,只要你别被它转来转去给弄混了还是可以看懂的。
hibernate怎么用查询
1:hibernate数据查询方式:有HQL方式,QBC方式,原生SQL方式。HQL适合静态查询,QBC则适合较多的动态查询。 A:HQL方式,支持条件查询,连接查询,分页查询,分组查询,内置函数和自定义函数查询(SUN(),MIN(),MAX()),子查询,动态绑定参数查。HQL语句定义如下: String hql=“from book“; Query query=session.createQuery(hql); B:QBC方式,也就是QBC检索方式。QBC通过Session类创建Criteria实例,通过不同方法进行检索,实际上Criteria是用来装载查询条件的容器。QBC有很多条件函数,如:Resstictions.eq(),Resstictions.gt(),Resstictions.ge(),Resstictions.le(),Resstictions.and(),Resstictions.or()等。Criteria容器使用方法如下: Criteria criteria=session.createCriteria(book.class); criteria.add(Restrications.It(“id“,new Integer(4))); List list=criteria.list(); C:原生SQL方式。不管是HQL还是QBC最终都要通过Hibernate来解析,把他们转换成SQL语句进行对数据库的操作。因为我们知道SQL可以在多平台之间使用。使用原生SQL方式如下: String sql=“select {b.*} from book b“ SQLQuery squery=session.createSQLQuery(sql); squery.addEntity(“b“,book.class); List list=squery.list();2:hibernate的关联查询 A:一对一关联: B:一对多,多对一关联 C:多对多关联 最后,要学hibernate,平时要多动手,慢慢积累经验,成就感就会也大,这样才能学而不厌。祝你学习进步。