Comments (2)
Persistable
is a Spring Data API to determine the identifier and whether an object is new or not. Persistable
is only used by Spring Data modules in which we fully control the object lifecycle such as Elasticsearch.
JPA handles object lifecycles on its own with the concept of attached entities hence Spring Data JPA doesn't make use of Persistable
for inserts vs. updates, instead, what you already found, whether to call EntityManager.merge(…)
vs. EntityManager.persist(…)
.
Generally speaking, if you use a single cache (Cache.cacheMap.get(md5)
) for two persistence technologies, after associating the object with your cache, all related store modules will use the same outcome for isNew
.
Ideally, you use the md5 value as primary key if that is what you're looking for.
from spring-data-jpa.
Persistable
seem to be unuseful in spring data jpa
.All operations depend on whether id
has value.I can't imagine what can i do with Persistable
.I think spring data jpa
and spring data elasticsearch
,they all belong to spring data
,
they implements Persistable
,They should have the same behavior
- if
document
’sid
has value and isNew=true will throw exception, isNew=false willselect by id
andupdate
; - if
document
’sid
is null and isNew=true willinsert
,isNew=false wll alsoinsert
;
from spring-data-jpa.
Related Issues (20)
- findById ignores @SQLRestriction annotation when performed in the same transaction as the save HOT 8
- Upgrade to Hibernate 6.5.1 HOT 1
- Remove duplicate plugin setup from parent pom.
- Invalid value for NanoOfSecond between 12am and 1am HOT 2
- Sorting of Pageable.unpaged(sort) is ignored by JPA Repository HOT 2
- Different `property` is used in `Sort.Order` method HOT 2
- Upgrade to Hibernate 6.2.25.Final
- Upgrade to Hibernate 6.4.8.Final
- Release 3.2.7 (2023.1.7)
- Release 3.3.1 (2024.0.1)
- Release 3.4 M1 (2024.1.0)
- 3.2.5 - Issue with dropping unexisting tables with ddl-auto=create HOT 1
- Upgrade to Jakarta Persistence 3.2
- Can I use global query comment instead `@QueryHint` or `@Meta`? HOT 2
- Specification using enum values does not follow `@Enumerated(EnumType.STRING)` and tries to convert it to smallint HOT 2
- Performance is slow when the query is like below (have in condition) and access on last page with large data HOT 4
- @Version column seems to cause JPA to delete subsequent inserts HOT 3
- Error found: java.lang.NoSuchMethodError: "_persistence_checkFetchedForSet(java.lang.String) with spring data JPA 3.3.0 HOT 3
- Error when using keyword queries which reference properties on a base class HOT 3
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from spring-data-jpa.