在关系数据库表中,主键用来识别记录,并保证每天记录的唯一性。在Java语言中,通过比较两个变量所引用对象的内存地址是否相同,或者比较两百变量引用的对象之是否相同来判断两对象是否相等。Hibernate为了解决二者之间的不同,使用对象标识符(OID)来标识对象的唯一性。OID是关系数据库中主键在Java对象模型中的等价物。在运行时,hibernate根据OID来维持Java对象和数据库表中的对应关系。如下代码所示:
- Transaction tx = session.beginTransaction();
- User user1 = (User) session.load(User.class, new Long(1));
- User user2 = (User) session.load(User.class, new Long(1));
- User user3 = (User) session.load(User.class, new Long(3));
应用程序在执行上述代码时,第一次假装OID为1的user对象,从数据库中查找ID为1的记录,然后创建想要的User实例,并把它保存的session缓存中,最后将该实例的引用赋值给变量user1,第二次加载OID为1的对象是,直接把session缓存中OID为1的实例的引用赋值给变量user2,因此,表达式user1=user2的结果为TRUE。