当前位置:首页>开发>正文

使用hibernate注解,怎样连接数据库 hibernate中inverse作用

2023-05-21 06:43:33 互联网 未知 开发

 使用hibernate注解,怎样连接数据库 hibernate中inverse作用

使用hibernate注解,怎样连接数据库

数据库不需要你连接阿,通过你的配置文件都可以看出,你配置好之后,hibernate帮你连上数据库,而你想得到一个session,可以通过SessionFactory来创建,由于你是用的annotation而不是XML,那具体代码如下:
Configuration cfg = new AnnotationConfiguration().config()
SessionFactory sf = cfg.buildSessionFactory()
Session session = sf.openSession()
这样就创建了一个session之后,就可以对数据库进行操作了。
但是用完别忘了释放资源哦,
close。

hibernate中inverse作用

inverse常用于一对多双向关联关系中。 以Student(学生)和Class(班级)为例,它们之间的关系为一对多的关系,即一个学生只能属于一个班级,一个班级可以包含多个学 生。 学生类定义代码: Class Student{ private int id private String name private Class class //省略getter()和setter()方法 } 班级类定义代码: Class Class{ private int id private String name private Set students = new HashSet() //省略getter()和setter()方法 } Student类的映射文件: Class类的映射文件: 希望你能对这两个映射文件所表达的数据库模式有正确的认识。即STUDENT表中存在一个名为CLASS_ID的字段,它和CLASS表中的ID字段是主外键关系。那个inverse属性就是用来规定是由谁(Student或Class)来维护这个主外键关系的。 inverse的默认值为false。 在处理逻辑代码中,如下: Class c1 = new Class() c1.setName("一班") Student s1 = new Student() Student s2 = new Student() s1.setName("Jason") s2.setName("Tom") c1.getStudents().add(s1) c2.getStudents().add(s2) s1.setClass(c1) s2.setClass(c1) //注释1 session.save(c1) 上面的代码会使Hibernate执行五条SQL语句,其中前三条是insert插入语句,后两条是update更新语句。插入就不用说了,那么为什么还要有更新语句呢?这是因为Class类映射文件的元素中指定了inverse="false",这就告之Hibernate:STUDENT表与CLASS表的主外键关系是由Class类来维护的。当执行save后,执行了三条insert语句,这三条语句中的后两条是插入到STUDENT表的,它们的CLASS_ID字段是通过s1.getClass().getID()取出的,假如我将上面“注释1”处修改为s2.setClass(c2)(c2是另一个Class对象,可能是持久化对象),这样,主外键关系不就乱了吗。为了保证主外键关系,Hibernate在这种情况下会再执行两条update语句来更改STUDENT表中两个新插入记录的CLASS_ID字段,当然,这时CLASS_ID字段的取值是从c1对象中直接取得,而不再是s1.getClass().getID()方式了。 如果我们将Class类映射文件的元素中的inverse属性修改为true,这就是告诉Hibernate:Class类不维护主外键关系了,这个任务就交给了Student类。于是,我们再执行上面的代码,Hibernate就会只执行三条insert语句,而不会执行任何update语句。因为Hibernate会通过Student类的s1.getClass().getID()和s2.getClass().getID()来确定CLASS_ID字段的值。 故,为了节省数据库资源,省却不必要的update语句,我们一般建议在一对多双向关联关系中,将一方的inverse属性设置为true,即将主外键的关系交由多方来维护。 打个比方:在一个公司中,是老板认识所有的员工容易,还是所有员工认识老板容易? 我是一个Hibernate的初学者,前两天刚刚研究了一下inverse属性,有所心得。写了这么多东西,希望能对你有所帮助。

最新文章