当前位置: 首页 > 面试题库 >

Hibernate代理对象包含什么?

上官羽
2023-03-14
问题内容

我可以从Google那里收集到的是:

  • Hibernate使用代理对象来实现延迟加载。当我们请求从数据库中加载对象,并且获取的对象具有对另一个具体对象的引用时,Hibernate返回一个代理而不是具体的关联对象。

  • Hibernate使用字节码检测(由Javassist提供)创建代理对象。Hibernate在运行时使用代码生成库创建我们的实体类的子类,并将实际对象替换为新创建的代理。

那么,代理对象到底包含什么?

它是否包含仅设置了id字段的骨架对象参考对象?当我们调用get方法时会设置Others字段吗?

Proxy对象是否包含JDBC语句以获取完全填充引用对象所需的所有数据。

还有其他我可能会想念的东西吗?

我不是要用勺子喂食,但如果您可以提供任何链接,都可以提供很好的信息。

对以上描述的任何更正也将受到欢迎。

例。

class Address {
   String city;
   String country;
}

class Person{
   int id;
   String name;
   Address address;
}

当我们尝试加载Person对象时,Hibernate会子类化Person类,例如:

class ProxyPerson extends Person {
       int id;
       String name;
       Address proxyCGLIBObject;
}

返回一个ProxyPerson对象。ProxyPerson的对象的id和name值,但Address的代理。

我对么?

在代理对象上添加toString()方法有什么期望?


问题答案:

这是一个非常常见的问题,因此此答案基于我博客上的这篇文章。

Hibernate代理用于替代实际的实体POJO(普通的旧Java对象)。

Proxy类在运行时生成,并且扩展了原始实体类。

Hibernate使用Proxy对象作为实体是为了允许延迟加载。

访问代理上的基本属性时,它只是将调用委派给原始实体。

每个ListSetMap在实体类型是由取代的PersistentListPersistentSetPersistentMap。这些类负责拦截对未初始化集合的调用。

代理不发出任何SQL语句。它仅触发一个InitializeCollectionEvent,该事件由关联的侦听器处理,该侦听器知道要发出哪个初始化查询(取决于配置的提取计划)。



 类似资料:
  • 问题内容: 我可以从Google那里收集到的是: Hibernate使用代理对象来实现延迟加载。当我们请求从数据库中加载对象,并且获取的对象具有对另一个具体对象的引用时,Hibernate返回一个代理而不是具体的关联对象。 Hibernate使用字节码检测(由Javassist提供)创建代理对象。Hibernate在运行时使用代码生成库创建我们的实体类的子类,并将实际对象替换为新创建的代理。 那么

  • 问题内容: 我有一个服务方法,该服务方法调用DAO,然后从数据库中返回一个对象。从系统的许多部分调用此方法。但是,一种特定的方法是将ObjectClass _ $$ _ javassist_somenumber的返回类型作为该类型。这是丢东西。我将service方法称为与其他任何地方完全相同的方法,那么为什么hibernate会返回代理而不是自然对象? 我知道有很多方法可以暴露“代理”对象,但是我

  • 我用的是Gson。toJSON方法。我的pojo包含一个属性作为URL字符串。奇怪的是Gson转换器改变了URL字符 输出为:/myApp/myAction。html?方法\U003Drooter\u0026cmd\u003d1 预期输出为:/myApp/myAction。html?方法=路由器

  • 问题内容: 我有两个Hibernate数据对象。第一个是用户(具有唯一的ID,用户名等),第二个是Collaborateable类。在这两者之间存在n对m的关系(带有Set的实现)。这意味着,一个用户使用许多可协作对象,而一个可协作对象具有许多用户。另外,一个可协作对象只有一个用户作为所有者。 我想实现一个Hibernate查询,该查询搜索具有特定用户作为所有者或在Collaborateable.

  • 我从accuweather获得了以下带有json的代码 我尝试通过Jackson将此对象解析为POJO 我有json中指定的所有模型,如、数组、,由组成(在json中命名为最小值和最大值)等,它们都有私有字段和公共构造函数、getter和setter。但是我没有一些字段,因为我想省略它们(Day、night、EpochDate、Source)。 当我运行程序时,我得到了错误 com.fasterx

  • 所以我的问题是,为什么交易未能将它从Hibernate代理转换为真正的对象?而且,如果我从上面的注释中删除(fetch=fetchtype.lazy)部分,这是一个变通方法吗?不过,我不愿意这样做,因为上面的代码实际上在Measure的父类中,它可能会对其他代码产生连锁反应。(为了更简单的说明,我移动了贸易属性来度量)。