我想使用Hibernate(4.3.6 Final)持久化一个以基本类型为键、非实体可嵌入复合类型值为值的映射。
我没有任何问题的基本类型作为键和值,我做了所有的方式一样,这是好的。当我将map值更改为可嵌入复合类型时遇到了问题,如下所示。
但我得到了错误:
原因:com.mysql.jdbc.exceptions.jdbc4.mysqlSyntaxerrorexception:“field list”中的列“hash”未知
你能帮助我做错了什么或者我错过了什么吗?
准备持久化我的映射的表
表user_address的映像
要在实体用户中持久存在的我的映射(片段)
@ElementCollection
@CollectionTable(name="USER_ADDRESS", joinColumns=@JoinColumn(name="USER_ID"))
@MapKeyColumn(name="ADDRESS_TYPE")
@AttributeOverrides({@AttributeOverride(name="addressLine1", column=@Column(name="USER_ADDRESS_LINE_1")),
@AttributeOverride(name="addressLine2", column=@Column(name="USER_ADDRESS_LINE_2"))})
private Map<String,Address> address = new HashMap<String, Address>();
可嵌入复合类型地址(片段)
@Embeddable
public class Address {
@Column(name="ADDRESS_LINE_1")
private String addressLine1;
@Column(name="ADDRESS_LINE_2")
private String addressLine2;
@Column(name="CITY")
private String city;
@Column(name="STATE")
private String state;
@Column(name="ZIP_CODE")
private String zipCode;
public Address() {
}
Main方法公共类应用程序{
public static void main(String[] args) {
Session session = HibernateUtil.getSessionFactory().openSession();
try {
Transaction transaction = session.beginTransaction();
User user = new User();
Address address = new Address();
Address address2 = new Address();
setAddressFields(address);
setAddressFields2(address2);
user.getAddress().put("ONE",address);
user.getAddress().put("TWO",address2);
setUserFields(user);
session.save(user);
transaction.commit();
} catch (Exception e) {
e.printStackTrace();
}finally{
session.close();
HibernateUtil.getSessionFactory().close();
}
}
private static void setUserFields(User user) {
user.setAge(22);
user.setBirthDate(new Date());
user.setCreatedBy("kmb");
user.setCreatedDate(new Date());
user.setEmailAddress("kmb385");
user.setFirstName("Kevin");
user.setLastName("bowersox");
user.setLastUpdatedBy("kevin");
user.setLastUpdatedDate(new Date());
}
private static void setAddressFields(Address address) {
address.setAddressLine1("Line 1");
address.setAddressLine2("Line 2");
address.setCity("New York");
address.setState("NY");
address.setZipCode("12345");
}
private static void setAddressFields2(Address address) {
address.setAddressLine1("Line 3");
address.setAddressLine2("Line 4");
address.setCity("Corning");
address.setState("NY");
address.setZipCode("12345");
}
}
错误全文:
最有趣的IMO错误监听片段
Hibernate尝试使用带有哈希和值sql insert,但当然,我的表中没有这些列。
DEBUG-插入USER_ADDRESS(USER_ID,hash,value,ADDRESS_LINE_1,ADDRESS_LINE_2,CITY,STATE,ZIP_CODE)值(?,?,?,?,?,?,?,?,?,?)Hibernate:插入USER_ADDRESS(USER_ID,html" target="_blank">hash,value,ADDRESS_LINE_1,ADDRESS_LINE_2,CITY,STATE,ZIP_CODE)值(?,?,?,?,?,?,?,?,?,?)
提前谢谢你的建议
我想我部分找到了解决办法。
@AttributeOverride有一个问题,我不知道为什么,因为我使用了完全相同的符号来持久化地址集合(可嵌入的复合类型)
我将非常感谢帮助为什么当我尝试重写列名时会出现问题,当我使用映射时,并且当我尝试持久化相同的可嵌入复合类型(地址)的集合时,一切都是ok的
当我更改类地址以避免重写列名时,我的映射成功地持久化了。换句话说,我更改了Address类型的列名,使其与user_address中的列名完全对应。
改变的复合可嵌入类型
现在列名与要持久映射的表中的列名完全对应
@Embeddable
public class Address {
@Column(name="USER_ADDRESS_LINE_1")
private String addressLine1;
@Column(name="USER_ADDRESS_LINE_2")
private String addressLine2;
@Column(name="CITY")
private String city;
@Column(name="STATE")
private String state;
@Column(name="ZIP_CODE")
private String zipCode;
public Address() {
}
...
映射到持久不重写
@ElementCollection
@CollectionTable(name="USER_ADDRESS", joinColumns=@JoinColumn(name="USER_ID"))
@MapKeyColumn(name="ADDRESS_TYPE")
@Columns(columns = {
@Column(name="USER_ADDRESS_LINE_1"),
@Column(name="USER_ADDRESS_LINE_2"),
@Column(name="CITY"),
@Column(name="STATE"),
@Column(name="ZIP_CODE")
})
private Map<String,Address> address = new HashMap<String, Address>();
Hibernate:插入USER_ADDRESS(USER_ID,ADDRESS_TYPE,USER_ADDRESS_LINE_1,USER_ADDRESS_LINE_2,CITY,STATE,ZIP_CODE)值(?,?,?,?,?,?,?,?)DEBUG-插入USER_ADDRESS(USER_ID,ADDRESS_TYPE,USER_ADDRESS_LINE_1,USER_ADDRESS_LINE_2,CITY,STATE,ZIP_CODE)值(?,?,?,?,?,?,?,?)Hibernate:插入USER_ADDRESS(USER_ID,ADDRESS_TYPE,USER_ADDRESS_LINE_1,USER_ADDRESS_LINE_2,CITY,STATE,ZIP_CODE)值(?,?,?,?,?,?,?,?)DEBUG-已完成插入集合:插入2行DEBUG-已提交JDBC连接DEBUG-hhh000420:关闭未释放的批处理DEBUG-释放JDBC连接DEBUG-释放JDBC连接DEBUG-hhh000031:关闭DEBUG-取消注册所有子ServiceRegistries信息时隐式销毁ServiceRegistry-hhh000030:清理连接池[JDBC:mysql://localhost:3306/ifinances]DEBUG-取消注册所有子ServiceRegistries时隐式销毁引导注册表
问题内容: 您好,我对hibernate世界非常陌生,似乎遇到了障碍。我需要存储的对象中有一个哈希映射。 事情是,我永远不需要使用此映射进行搜索,排序或做任何事情,我只需要将其与对象一起保存并在加载对象时加载它,因此我希望hibernate可以通过某种方式对其进行序列化然后将其存储在CLOB或BLOB字段中,但是我似乎找不到任何方法。 所以我接下来试图让hibernate保存这样 但这在运行时给了
持久化类(Persistent Object )简称 PO,在 Hibernate 中, PO 是由 POJO(即 java 类或实体类)和 hbm 映射配置组成。 简单点说,持久化类本质上就是一个与数据库表建立了映射关系的普通 Java 类(实体类),例如 User 类与数据库中 user 表通过映射文件 User.hbm.xml 建立了映射关系,此时 User 就是一个持久化类。 持久化类的规
问题内容: JPA和Hibernate当前都不支持JDK8中JSR-310带来的新日期/时间类(JPA 票证,Hibernate 票证)。尽管如此,我还是希望使用JDK8日期/时间类进行编码,因为它们最终经过了精心设计。特别是,我对感兴趣,而不是不完全支持所有类型,因为我的所有实体都将使用此特定类(或者,所以我认为现在至少是:-) 一种选择是编写一个JPA 2.1定义的类型转换器。但是,我们的应用
无法提交JPA事务;嵌套异常是javax.persistence.RollBackException:提交事务时出错 是否可以在PostPersisted方法中保存此operationHistoryEntity对象?我想我可以用@EntityListeners注释实体,然后将数据库中关于新的、修改的或删除的记录的信息保存到OperationHistory表中。
问题内容: 我试图在spring启动时将JSON对象存储在MySQL数据库中。我知道我做错了事,但是我无法弄清楚到底是什么原因,因为我对Spring还很陌生。 我有一个休息端点,在这里我通过HTTP PUT获取以下JSON对象,并且需要将其存储在数据库中,以便用户以后可以通过HTTP GET获取它。 请注意,在上述情况下,对象 中* 键 的 数量 可能会有所不同,由于该要求,我正在使用a 来捕获控
我想保留一个文件,即使在卸载了我的应用程序在Android11。多亏了Android10和11关于存储的更新,我不能再这样做了。另外,我不想使用数据备份或远程服务器,它必须离线。有什么建议吗?