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

轻量级的ORM而不是休眠-强大而敏捷

濮阳钟展
2023-03-14
问题内容

我用谷歌搜索了短语“ j2ee的轻量级ORM”并找到了此页面http://java-source.net/open-
source/persistence
从结果之一。我的目标是找到一个比Hibernate轻巧的ORM框架,并提供一些对我来说最重要的hibernate功能,例如:自动表生成和延迟初始化,并且不要给我麻烦的时间使用表和地图以及采集。同样重要的是,即将到来的ORM具有围绕它的社区,这可以更快地找到错误和错误的解决方案。而且,新的orm对我隐藏数据库也很重要(需要更少的sql技能和更多的OO)。到目前为止,我已经将选择范围缩小到了iBatis(myBatis)和ORMLite。我希望这个ORM用于我的新项目,它是j2ee中的桌面应用程序,因此,这个orm的启动时间要比其他时间少(与Hibernate相比,它需要很多时间才能首次运行,特别是当您有很多东西时,这很重要)表)

n


问题答案:

恐怕您可能对概念有误解。您基本上不是在寻找Hibernate的替代品,而是ORM的替代品。

hibernate是进行 正确ORM 的极少数尝试之一。Hibernate试图解决 大多数 对象/关系不匹配的范例。那些是:

  • 粒度问题
  • 亚型问题
  • 身份问题
  • 与协会有关的问题
  • 数据导航问题

有关更多信息,请参见Java Persistence with Hibernate。

综上所述,没有更轻的ORM之类的东西。有适当的ORM解决方案,也有其他解决方案(例如myBatis),在这些解决方案中,不是将关系模型映射到对象模型,
而是将SQL语句映射到对象和方法

而且不要忘记-您不必使用所有的Hibernate功能。您可以轻松地将其与自定义SQL,纯JDBC混合使用,并仅使用其功能的一部分。

edit1:关于启动缓慢

Intermezzo
:我目前正在使用一种专有的ORM解决方案(不像Hibernate那样聪明),它专门针对我们的应用进行了调整。最大的问题也是启动,因为将整个数据库映射到对象根本不是一件容易的事。

现在,至于hibernate。也许您知道,Hibernate在启动时还会生成CRUD
SQL语句。如果您的html" target="_blank">数据库很大,则可能会影响性能。但是,您可以关闭此启动SQL的生成,然后切换到在运行时生成的动态语句。

使用XML表示法,可以这样实现:

<class name="SomeClass"
    dynamic-insert="true"
    dynamic-update="true">
...
</class>

或带有Hibernate注释:

@Entity
@org.hibernate.annotations.Entity(
    dynamicInsert = true, dynamicUpdate = true
)
public class SomeClass { ...

edit2:关于混合自定义SQL

参考书《 Java PersistencewithHibernate》相当深入地解释了事情。第8章是关于使用旧数据库的,它还提示了如何更改DML(与自定义SQL一样,您甚至可以用自定义SQL替换CRUD代码!)和DDL(通用运行时DDL操作)。你应该偷看那里:)



 类似资料:
  • 问题内容: 如何获得Hibernate(使用JPA)来创建MySQL InnoDB表(而不是MyISAM)?我发现了使用Hibernate生成SQL文件创建表时可以使用的解决方案,但是没有“运行中”的方法。 问题答案: 您不能指定hibernate方言并使用 编辑 从MySQL版本> 5.1开始,应该是 为了避免遇到此问题,在MySQL中使用“ TYPE = InnoDB”会引发异常

  • 问题内容: hibernate命名查询为数据类型为NUMBER的列返回BigDecimal。 在客户端,我希望col1的数据类型很长(原始),我这样做: 要么 在两种情况下,我得到: 我怎样才能解决这个问题?我怀疑,混叠有问题吗? 问题答案: 默认情况下,Oracle NUMBER映射到Hibernate中的BigDecimal。尝试将类型设置为BigDecimal。

  • 问题内容: 我在某些文章中读到,在hibernate状态下DAO不是强制性的,其实现是“取决于”的,换句话说,我们可以在ORM与DAO模式之间进行选择。 好的,假设我不想使用DAO模式,所以我只使用了由hibernate(my ORM)提供的会话CRUD和查询操作。 特别是对于“搜索”和“查找”查询而言,始终重写它们是不正确的,因此将它们放入一个类是合理的想法。 但是,此类是一个简单的DAO,而没

  • 问题内容: 该程序一个接一个地执行数以万计的连续插入。我以前从未使用过Hibernate。我的性能变得非常慢(如果我只是手动连接并执行SQL,则速度会提高10-12倍。根据许多休眠教程,我的batch_size设置为50。 这是单个插入的日志-也许您可以帮助我准确了解正在发生的事情: 问题答案: 当您调用时,hibernate将生成一个INSERT SQL。该INSERT SQL将附加在刷新期间(

  • 问题内容: 我有一些实体具有一对一的懒惰关系(为简洁起见,省略了逻辑): 在某些(非常罕见)的情况下,我想热切地加载A及其所有关联的实例。这样做的原因是我想对该A实例及其整个子实例进行一些修改,然后根据用户输入保存或丢弃它们。 如果要按需加载内容,则必须根据用户请求将实体重新附加到新的会话,但是这些实体正在被修改,并且修改不应持久化。 所以我写这样的东西: 当我尝试访问内容时,出现以下异常: 如果

  • 问题内容: 我有一个关于Hibernate的一般性问题,我正在与之讨论。 我有A类和B类,其中B依赖于A 在我的代码中,当我调用em.persist(objOfTypeA)时,我希望插入内容能够插入到表AAA和BBB中。如果我手动使用A获取A的ID并将其填写在每个对象的列表中,然后保留该列表,则说明一切正常。但是我希望Hibernate 能够 神奇地 做到这一点。 难道我做错了什么?还是我只是对H