gpt4 book ai didi

java - JPA 查询返回 Object[] 而不是所需的实体

转载 作者:行者123 更新时间:2023-11-30 07:01:56 25 4
gpt4 key购买 nike

我使用这段代码对 sql server 数据库进行查询:

List<Continent> continents = new ArrayList<>();
List<Object[]> tuples = (List<Object[]>) em.createNativeQuery("SELECT * FROM Continents").getResultList();
for (Object[] tuple : tuples) {

System.out.println(tuple[0]);

}
return continents;

我使用此代码是因为我无法直接从数据库中获取所需的实体类型(大陆)。

我的查询应该是什么样的?

这是我的大陆类(class)的开始:

@Entity
@Table
public class Continent implements Serializable {
@Column(name = "Name")
private StringProperty name;
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "ContinentID")
private IntegerProperty continentId;
@OneToMany(mappedBy="continent")
private Connection connection;
List<Country> countries;


public Continent(String naam) throws SQLException {
name = new SimpleStringProperty(naam);
continentId = new SimpleIntegerProperty();
}

protected Continent()
{}

这是我的 persistence.xml 文件:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.1" xmlns="http://xmlns.jcp.org/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd">
<persistence-unit name="HOGENT1415_11" transaction-type="RESOURCE_LOCAL">
<provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
<class>domain.Continent</class>
<properties>
<property name="javax.persistence.jdbc.url" value="jdbc:sqlserver://localhost:1433;databaseName=HOGENT1415_11"/>
<property name="javax.persistence.jdbc.user" value="sa"/>
<property name="javax.persistence.jdbc.driver" value="com.microsoft.sqlserver.jdbc.SQLServerDriver"/>
<property name="javax.persistence.jdbc.password" value="root"/>
</properties>
</persistence-unit>
</persistence>

最佳答案

如果您使用 native 查询,您应该提供结果类:

List<Continent> tuples = em.createNativeQuery("SELECT * FROM Continents", Continent.class).getResultList();

或者只使用 jpql 查询:

List<Continent> tuples = em.createQuery("SELECT c FROM Continent c", Continent.class).getResultList();

在第二个示例中,结果类是可选的,但通过这种方式您可以获得 TypedQuery 并且可以避免强制转换。请注意,在 jpql 的情况下,您提供的是实体名称,而不是像 native 查询中那样的表名称。

关于java - JPA 查询返回 Object[] 而不是所需的实体,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29416825/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com