- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在映射继承层次结构,如下所示:
这里的问题是,数据库包含分别代表人员、俱乐部和竞技场的单字符枚举值“P”、“C”和“A”,但要使用的 Java 枚举值应该是人物、俱乐部和竞技场。
这需要使用 AttributeConverter
来执行 DB 值 - Java 枚举转换(请参阅下面的映射):
联系实体:
@Entity
@Table(name="Contacts")
@Inheritance(strategy=InheritanceType.JOINED)
public abstract class Contact extends BaseIdEntity
{
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
@Column
protected Integer id;
@Convert(converter=ContactTypeConverter.class) // <-- !!! ... see below
@Enumerated(EnumType.STRING)
@Basic(optional=false)
@Column
protected ContactType type; // actually a discriminator, but for JOINED inheritance, it is not required to annotate the class with @DiscriminatorColumn
...
}
联系人类型枚举:
public enum ContactType
{
PERSON, <-- fully written, but data is single-char
CLUB,
ARENA;
}
人实体:
@Entity
@Table(name="Persons")
public class Person extends Contact
{
private static final long serialVersionUID = 1L;
@Basic(optional=false)
@Column(name="first_name")
private String firstName;
@Basic(optional=false)
@Column(name="last_name")
private String lastName;
...
}
俱乐部实体:
@Entity
@Table(name="Clubs")
public class Club extends Contact
{
private static final long serialVersionUID = 1L;
@Basic(optional=false)
@Column
private String name;
@Basic(optional=false)
@Column
private String code;
@Basic
@Column(name="website_url")
private String websiteUrl;
...
}
竞技场实体:
@Entity
@Table(name="Arenas")
public class Arena extends Contact
{
private static final long serialVersionUID = 1L;
@Basic(optional=false)
@Column
private String name;
@Basic
@Column
private Integer capacity;
...
}
ContactType
的属性转换器:
@Converter( autoApply = false )
public class ContactTypeConverter implements AttributeConverter<ContactType, String>
{
@Override
public String convertToDatabaseColumn( ContactType contactType )
{
System.out.println( "convertToEntityAttribute(" + contactType + ")" );
switch ( contactType )
{
case PERSON:
return "P";
case CLUB:
return "C";
case ARENA:
return "A";
default:
throw new IllegalArgumentException( "Unknown enum value: " + contactType );
}
}
@Override
public ContactType convertToEntityAttribute( String value )
{
System.out.println( "convertToEntityAttribute(\"" + value + "\")" );
switch ( value )
{
case "P":
return PERSON;
case "C":
return CLUB;
case "A":
return ARENA;
default:
throw new IllegalArgumentException( "Unknown DB value: " + value );
}
}
}
这是 MySQL 的 DDL + 数据:
CREATE TABLE `Contacts`(
`id` INT(11) NOT NULL AUTO_INCREMENT,
`type` ENUM('P', 'C', 'A') NOT NULL,
PRIMARY KEY (`id`));
CREATE TABLE `Arenas` (
`id` INT(11) NOT NULL,
`name` VARCHAR(50) NOT NULL,
`capacity` INT(11) NULL,
PRIMARY KEY (`id`),
CONSTRAINT `arenas_contacts_fk`
FOREIGN KEY (`id`)
REFERENCES `Contacts` (`id`)
ON DELETE CASCADE
ON UPDATE CASCADE);
CREATE TABLE `Clubs` (
`id` INT(11) NOT NULL,
`name` VARCHAR(50) NOT NULL,
`code` VARCHAR(5) NOT NULL,
`website_url` VARCHAR(64) NULL DEFAULT NULL,
PRIMARY KEY (`id`),
CONSTRAINT `clubs_contacts_fk`
FOREIGN KEY (`id`)
REFERENCES `Contacts` (`id`)
ON DELETE CASCADE
ON UPDATE CASCADE);
CREATE TABLE `Persons` (
`id` INT(11) NOT NULL,
`first_name` VARCHAR(50) NOT NULL,
`last_name` VARCHAR(50) NOT NULL,
PRIMARY KEY (`id`),
CONSTRAINT `persons_contacts_fk`
FOREIGN KEY (`id`)
REFERENCES `Contacts` (`id`)
ON DELETE CASCADE
ON UPDATE CASCADE);
数据:
INSERT INTO `Contacts` (`id`, `type`) VALUES
( 1, 'P'),
( 2, 'P'),
( 3, 'P'),
( 26, 'P'),
( 99, 'P'),
(101, 'C'),
(102, 'C'),
(103, 'C'),
(201, 'A'),
(202, 'A'),
(203, 'A');
INSERT INTO `Persons` (`id`, `first_name`, `last_name`) VALUES
( 1, 'Kay', 'Wundrak'),
( 2, 'Joe', 'Locke'),
( 3, 'Ahmed', 'Thiab'),
( 26, 'Seb', 'Gottwalk'),
( 99, 'Test', 'Test');
INSERT IGNORE INTO `Clubs` (`id`, `name`, `code`) VALUES
(101, 'TV Dieburg', 'DIEB'),
(102, 'SC Rist Wedel', 'RIST'),
(103, 'BBG Herford', 'HERF');
INSERT IGNORE INTO `Arenas` (`id`, `name`, `capacity`) VALUES
(201, 'Schlossgartenhalle', NULL),
(202, 'Steinberghalle', NULL),
(203, 'Halle am Gymnasium', NULL);
我查阅了很多资料,例如
https://www.nurkiewicz.com/2013/06/mapping-enums-done-right-with-convert.html [主要]
https://thoughts-on-java.org/jpa-21-type-converter-better-way-to/
https://thoughts-on-java.org/jpa-21-how-to-implement-type-converter/
https://www.baeldung.com/jpa-persisting-enums-in-jpa
http://eloquentdeveloper.com/2016/07/18/persisting-enums-using-jpa-attribute-converter/
都说一样,但是不行。加载人员列表时,我得到:
Caused by: java.lang.IllegalArgumentException: No enum constant net.bbstats.entity.ContactType.P
at java.lang.Enum.valueOf(Enum.java:238)
at org.hibernate.type.descriptor.java.EnumJavaTypeDescriptor.fromName(EnumJavaTypeDescriptor.java:84)
at org.hibernate.metamodel.model.convert.internal.NamedEnumValueConverter.toDomainValue(NamedEnumValueConverter.java:39)
at org.hibernate.metamodel.model.convert.internal.NamedEnumValueConverter.readValue(NamedEnumValueConverter.java:69)
at org.hibernate.type.EnumType.nullSafeGet(EnumType.java:250)
at org.hibernate.type.CustomType.nullSafeGet(CustomType.java:119)
at org.hibernate.type.AbstractType.hydrate(AbstractType.java:91)
at org.hibernate.persister.entity.AbstractEntityPersister.hydrate(AbstractEntityPersister.java:3007)
at org.hibernate.loader.Loader.loadFromResultSet(Loader.java:1746)
at org.hibernate.loader.Loader.instanceNotYetLoaded(Loader.java:1672)
at org.hibernate.loader.Loader.getRow(Loader.java:1561)
at org.hibernate.loader.Loader.getRowFromResultSet(Loader.java:731)
at org.hibernate.loader.Loader.processResultSet(Loader.java:990)
at org.hibernate.loader.Loader.doQuery(Loader.java:948)
at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:340)
at org.hibernate.loader.Loader.doList(Loader.java:2689)
at org.hibernate.loader.Loader.doList(Loader.java:2672)
at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2506)
at org.hibernate.loader.Loader.list(Loader.java:2501)
at org.hibernate.loader.hql.QueryLoader.list(QueryLoader.java:504)
at org.hibernate.hql.internal.ast.QueryTranslatorImpl.list(QueryTranslatorImpl.java:395)
at org.hibernate.engine.query.spi.HQLQueryPlan.performList(HQLQueryPlan.java:220)
at org.hibernate.internal.SessionImpl.list(SessionImpl.java:1508)
at org.hibernate.query.internal.AbstractProducedQuery.doList(AbstractProducedQuery.java:1537)
at org.hibernate.query.internal.AbstractProducedQuery.list(AbstractProducedQuery.java:1505)
at org.hibernate.query.Query.getResultList(Query.java:135)
at net.bbstats.framework.service.Repository.findByNamedQuery(Repository.java:184)
at net.bbstats.framework.service.BaseEntityService.findByNamedQuery(BaseEntityService.java:382)
at net.bbstats.framework.service.BaseEntityService.findByNamedQuery(BaseEntityService.java:368)
at net.bbstats.framework.service.BaseEntityService.findByNamedQuery(BaseEntityService.java:344)
at net.bbstats.framework.service.BaseEntityService.findAllByQueryWithFetchGraph(BaseEntityService.java:300)
... 179 more
看行:
java.lang.IllegalArgumentException:没有枚举常量 net.bbstats.entity.ContactType.P
没有真正正确转换或根本没有转换...?
问题:
这里出了什么问题?我几乎 100% 确定映射是正确的...
-> 这是一个 Hibernate 错误吗? 是因为继承映射吗?也许不适用于 InheritanceType.JOINED
?
无论如何,一个观察结果是,无论如何,属性转换器永远不会被调用,即 ContactTypeConverter
中不会到达任何断点,并且不会出现任何系统输出曾经打印到控制台/日志。
设置:WildFly 14.0.1.Final、Hibernate 5.3.6.Final
最佳答案
根据this .
JPA explicitly disallows the use of an
AttributeConverter
with an attribute marked as@Enumerated
. So, when using theAttributeConverter
approach, be sure not to mark the attribute as@Enumerated
.
关于java - 在 InheritanceType.JOINED 中使用 AttributeConverter 映射 MySQL ENUM 在 Hibernate 5.3.6 (JPA 2.1+) : No enum constant 上抛出 IllegalArgumentException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59422281/
我需要将文本放在 中在一个 Div 中,在另一个 Div 中,在另一个 Div 中。所以这是它的样子: #document Change PIN
奇怪的事情发生了。 我有一个基本的 html 代码。 html,头部, body 。(因为我收到了一些反对票,这里是完整的代码) 这是我的CSS: html { backgroun
我正在尝试将 Assets 中的一组图像加载到 UICollectionview 中存在的 ImageView 中,但每当我运行应用程序时它都会显示错误。而且也没有显示图像。 我在ViewDidLoa
我需要根据带参数的 perl 脚本的输出更改一些环境变量。在 tcsh 中,我可以使用别名命令来评估 perl 脚本的输出。 tcsh: alias setsdk 'eval `/localhome/
我使用 Windows 身份验证创建了一个新的 Blazor(服务器端)应用程序,并使用 IIS Express 运行它。它将显示一条消息“Hello Domain\User!”来自右上方的以下 Ra
这是我的方法 void login(Event event);我想知道 Kotlin 中应该如何 最佳答案 在 Kotlin 中通配符运算符是 * 。它指示编译器它是未知的,但一旦知道,就不会有其他类
看下面的代码 for story in book if story.title.length < 140 - var story
我正在尝试用 C 语言学习字符串处理。我写了一个程序,它存储了一些音乐轨道,并帮助用户检查他/她想到的歌曲是否存在于存储的轨道中。这是通过要求用户输入一串字符来完成的。然后程序使用 strstr()
我正在学习 sscanf 并遇到如下格式字符串: sscanf("%[^:]:%[^*=]%*[*=]%n",a,b,&c); 我理解 %[^:] 部分意味着扫描直到遇到 ':' 并将其分配给 a。:
def char_check(x,y): if (str(x) in y or x.find(y) > -1) or (str(y) in x or y.find(x) > -1):
我有一种情况,我想将文本文件中的现有行包含到一个新 block 中。 line 1 line 2 line in block line 3 line 4 应该变成 line 1 line 2 line
我有一个新项目,我正在尝试设置 Django 调试工具栏。首先,我尝试了快速设置,它只涉及将 'debug_toolbar' 添加到我的已安装应用程序列表中。有了这个,当我转到我的根 URL 时,调试
在 Matlab 中,如果我有一个函数 f,例如签名是 f(a,b,c),我可以创建一个只有一个变量 b 的函数,它将使用固定的 a=a1 和 c=c1 调用 f: g = @(b) f(a1, b,
我不明白为什么 ForEach 中的元素之间有多余的垂直间距在 VStack 里面在 ScrollView 里面使用 GeometryReader 时渲染自定义水平分隔线。 Scrol
我想知道,是否有关于何时使用 session 和 cookie 的指南或最佳实践? 什么应该和什么不应该存储在其中?谢谢! 最佳答案 这些文档很好地了解了 session cookie 的安全问题以及
我在 scipy/numpy 中有一个 Nx3 矩阵,我想用它制作一个 3 维条形图,其中 X 轴和 Y 轴由矩阵的第一列和第二列的值、高度确定每个条形的 是矩阵中的第三列,条形的数量由 N 确定。
假设我用两种不同的方式初始化信号量 sem_init(&randomsem,0,1) sem_init(&randomsem,0,0) 现在, sem_wait(&randomsem) 在这两种情况下
我怀疑该值如何存储在“WORD”中,因为 PStr 包含实际输出。? 既然Pstr中存储的是小写到大写的字母,那么在printf中如何将其给出为“WORD”。有人可以吗?解释一下? #include
我有一个 3x3 数组: var my_array = [[0,1,2], [3,4,5], [6,7,8]]; 并想获得它的第一个 2
我意识到您可以使用如下方式轻松检查焦点: var hasFocus = true; $(window).blur(function(){ hasFocus = false; }); $(win
我是一名优秀的程序员,十分优秀!