草庐IT

hibernate-postgresql

全部标签

java - 带有 postgresql 的串行列上的 Spring Data JPA "null value in column xxx violates not-null constraint"

我的实体有一个mapOrder字段,我希望它像下面这样自动递增:@EntitypublicclassMap{@Id@GeneratedValue(strategy=GenerationType.IDENTITY)privateLongid;@Column(columnDefinition="serial")privateLongmapOrder;//.......}生成的sql看起来不错:CREATETABLEmap(idbigserialNOTNULL,map_orderserialNOTNULL,...)但是当我用SpringDataJPA的存储库保存它时,像这样:Mapm=new

java - 使用 Spring AOP 配置 Hibernate session

我有一个SpringFramework4应用程序,它使用Hibernate4.3.8作为JPA提供程序。我想使用Hibernate过滤器,因此我需要启用它们。我想在应用程序中全局执行此操作,我正在尝试使用SpringAOP来执行此操作。我的想法是,我可以编写一个方面,在每次创建/获取session时启用过滤器,就像在this中一样。和this问题。我已将spring-aop和aspectjweaver依赖项添加到我的项目中(使用Maven)。我添加了以下方面。@Aspect@ComponentpublicclassEnableHibernateFilters{@Pointcut("ex

java - 使用 Infinispan 和 Wildfly 配置 Hibernate 搜索

我正在配置HibernateSearch5.5.5以在Wildfly10上使用Infinispan8.2.2。我在Wildfly中只配置了Infinispan模块,没有配置HibernateSearch模块。在persistence.xml中我放置了这个配置:这是因为似乎使用了Infinispan,但并未保留索引。所有缓存都在domain.xml中配置如下:在jboss-deployment-structure.xml中:当我尝试索引所有内容时,我收到此错误:UNHANDLED_EXCEPTION:java.lang.IllegalArgumentException:java.lang

java - hibernate 多对多关联不更新连接表

在我的应用程序中,我在User和Preference实体之间建立了多对多关联。由于连接表需要一个额外的列,我不得不将其分解为2个一对多关联:用户实体:@OneToMany(mappedBy="user",fetch=FetchType.EAGER,cascade={CascadeType.PERSIST,CascadeType.MERGE},orphanRemoval=true)publicSetgetPreferences(){returnpreferences;}偏好实体:@OneToMany(mappedBy="preference",fetch=FetchType.EAGER)

java - 从 JPA/Hibernate 注释类生成 ER 图的 Ant 任务

有人知道可以做到这一点的工具吗?Linguinemaps似乎只适用于旧的hibernatexml文件。而hibernate工具任务hbm2hbmxml似乎有abug这样我就不能执行两步过程“annotations->hbmxml->diagram”最好的,安德斯 最佳答案 嗯,我找到了thisgreatpostondeveloperworks.作者似乎从实时数据库生成实体图。我想知道我是否可以去“带注释的类->实时数据库(例如H2)->SchemasSpy生成的图表?是的,APIViz看起来很棒。我已经bloggedmyhackys

java - hibernate/Ehcache : evicting collections from 2nd level cache not synchronized with other DB reads

我有一个使用JPA、Hibernate和ehcache的应用程序,以及Spring的声明式交易。数据库上的负载相当高,因此所有内容都被缓存以加快速度,包括Collection品。现在集合被单独缓存已经不是什么secret了来自拥有它们的实体,所以如果我删除一个作为此类元素的实体缓存集合,持久化一个应该是一个元素的实体,或者更新一个实体使得它从一个集合移动到另一个集合,我必须执行驱逐手工制作。所以我使用了一个hibernate事件监听器,它跟踪实体被插入、删除或更新并保存该信息以用于在Spring中注册的事务同步事务管理器采取行动。一旦事务已提交。现在的问题是很多时候,一些其他并发事务设

java - 如何在 Hibernate 中以单向多对一的方式离开联接表?

我正在使用Howtojointablesinunidirectionalmany-to-onecondition?.如果你有两个类:classA{@IdpublicLongid;}classB{@IdpublicLongid;@ManyToOne@JoinColumn(name="parent_id",referencedColumnName="id")publicAparent;}B->A是多对一关系。我知道我可以将B的集合添加到A,但我不希望这种关联。所以我的实际问题是,是否有创建SQL查询的HQL或Criteria方法:select*fromAleftjoinBon(b.pare

java - 是否可以从 Hibernate Criteria 中删除订单?

如果我在对象上有一个@OrderBy("someProperty")注释,然后使用Criteria添加一个ORDERBY子句,如下所示:criteria.addOrder(Order.asc("id"));生成的SQL将执行如下排序:ORDERBYsomeProperty,idasc是否可以改变两者的顺序或者去掉someProperty的顺序?我无法删除@OrderBy注释并且我正在使用HibernateforJava。 最佳答案 Criteria没有删除Order的方法都不是CriterionOrder类非常有限,您只能使用属性名

java - Spring 3.1 + Hibernate 4.1 Propagation.Supports 问题

我正在将我的项目从Spring3.0+hibernate3.6.x迁移到S3.1+H4.1我的新代码如下org.hibernate.dialect.xtrueupdatetruex.y.z.entities.Student当将getStudent方法标记作为SUPPORTS运行并且只读时,我得到了org.hibernate.HibernateException:NoSessionfoundforcurrentthreadatorg.springframework.orm.hibernate4.SpringSessionContext.currentSession(SpringSessi

java - hibernate 中查询参数为 null 或为空时如何处理?

我正在使用JPA,hibernate3。StringsqlQuery="FROMTraceEntityVOwherelotNumber=:lotNumberandmfrLocId=:mfrLocIdandmfrDate=:mfrDateandqtyInitial=:qtyInitialandexpDate=:expDate";Queryquery=entityManager.createQuery(sqlQuery).setParameter("lotNumber",traceEntityVO.getLotNumber()).setParameter("mfrLocId",traceE