- 
 
- 
  Notifications
 You must be signed in to change notification settings 
- Fork 3.7k
mapping a class multiple times / persisting Maps #5539
-
From https://hibernate.atlassian.net/browse/HHH-15698:
We’ve deprecated the hbm.xml format without providing any replacement way to map a class with two different entity names. We have jumped through hoops in our APIs and internal implementation to support this usage.
Actually, just how deprecated is it really? Sure, we don't really document it, but nor do we document orm.xml. The documentation is basically completely silent on the subject of XML-based mappings and you're supposed to do them.
There's no straightforward way out of this, either:
- we un-deprecate hbm.xml,since it's the only way to specify an explicit entity name,
- introduce a brand new XML mapping format, derived from orm.xml, but with the ability to specify entity names for entities and associations, or
- we deprecate the remaining methods of Sessionthat accept a stringentityName, since they’re only useful with the deprecatedhbm.xmlmapping format.
Note that it would not help to introduce new annotations, since you can’t define multiple mappings for a single class in annotations. (Nor you can you define mappings for Maps.)
So what we’re contemplating here is losing:
- the ability to map a class multiple times with different entity names, and
- the ability to persist a Map.
Beta Was this translation helpful? Give feedback.
All reactions
Replies: 1 comment 2 replies
-
As far as I understand, the <entity/> tag supports specifying a class and name attribute, so mapping the same class under a different name should be doable. The association mappings in XML also don't seem to require interpreting the explicit attribute target-entity as class, so maybe we can already do what you are looking for. Users would simply have to use the class java.util.Map since the class attribute of <entity/> is required.
Steve already started working on orm.xml extensions, so if we want further extensions, we can put that there.
Beta Was this translation helpful? Give feedback.
All reactions
-
Yeah that's what I thought initially (it's what I tried writing) but it's certainly not how we're interpreting these things right now.
But perhaps we could change it so that name is interpreted as a real entity name, and not just as an abbreviation in the query language. (It's not quite as simple as that, but probably we could make it work without too much breakage.)
So yeah, maybe you're right.
Steve already started working on
orm.xmlextensions, so if we want further extensions, we can put that there.
Yeah, yeah, what I came back here to say was: isn't this something we could handle with XML namespaces? I had forgotten about them.
Beta Was this translation helpful? Give feedback.
All reactions
-
I'm not understanding the thought process with namespace, so hard to say. IIUC you are asking whether we can "replace" certain XSD types (<entity/>, etc) with our own. The answer is no. Its a rabbit hole. The only way to refer to our custom <entity/> type is to also replace its container (<entity-mappings/>), and on and on.
Beta Was this translation helpful? Give feedback.