当我尝试使用 JPA(Hibernate 实现)将实体映射到表时,我发现了一些令人困惑的地方
当我在 getter 上使用注解时,一切正常
@Column(name = "main_battery_voltage", precision = 2)
public float getMainBatteryVoltage() {
return mainBatteryVoltage;
}
但是当我在字段上尝试同样的事情时,会使用字段名和属性
@Column(name = "main_battery_voltage", precision = 2)
private float mainBatteryVoltage;
系统忽略名称属性,以数据库中的列名称 mainBatteryVoltage 运行,因此任务失败。
我正在使用 MySQL,这是 persistence.xml
<?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence" version="2.0">
<persistence-unit name="SolarPersistenceUnit">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<class>com.cs.solar.db.entity.User</class>
<class>com.cs.solar.db.entity.Lamp</class>
<class>com.cs.solar.db.entity.Project</class>
<properties>
<property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect"/>
<!--<property name="hibernate.dialect" value="org.hibernate.dialect.HSQLDialect"/>-->
<property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver"/>
<property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/SOLAR"/>
<property name="hibernate.connection.username" value="root" />
<property name="hibernate.connection.password" value="admin" />
<property name="hibernate.connection.autocommit" value="false"/>
<property name="hibernate.show_sql" value="true" />
<property name="hibernate.format_sql" value="true" />
<property name="hibernate.max_fetch_depth" value="3"/>
</properties>
</persistence-unit>
<persistence-unit name="TestSolar" />
</persistence>
虽然现在可以用了,但我很好奇是什么原因造成的,谢谢
最佳答案
你可以在这里找到一个简短的解释:
Hibernate Annotation Placement Question
重点是:
“Hibernate 使用的访问类型将是字段或属性。EJB3 规范要求您在将被访问的元素类型上声明注释,即 如果您使用属性访问,则为 getter 方法,如果您使用字段访问,则为字段。应避免在字段和方法中混合使用 EJB3 注释。Hibernate 会猜测访问类型..."
关于java - name 属性似乎在 Field 中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12888451/