Hibernate MYSQL 本机查询抛出 ClassCastException
Hibernate MYSQL native query throws ClassCastException
正在使用 Hibernate 从 table 中检索整数值,发生以下异常,
java.lang.ClassCastException: java.lang.Integer cannot be cast to
pojo.Datasetstatus
String q1="SELECT datasetstatusID from datasetstatus where DatasetID='"+meta_dataset+"'";
Query query=session.createSQLQuery(q1);
List<Datasetstatus> dobj=query.list();
for(Datasetstatus dobj1: dobj) {
System.out.println("Value :: "+dobj1.getDatasetStatusId());
}
Pojo class 格式,
public class Datasetstatus implements java.io.Serializable {
private Integer datasetStatusId;
private String datasetId;
public Datasetstatus(String datasetId) {
this.datasetId = datasetId;
}
public Integer getDatasetStatusId() {
return this.datasetStatusId;
}
public void setDatasetStatusId(Integer datasetStatusId) {
this.datasetStatusId = datasetStatusId;
}
public String getDatasetId() {
return this.datasetId;
}
public void setDatasetId(String datasetId) {
this.datasetId = datasetId;
}
}
如果有解决这个问题的建议
您的查询似乎有问题。您使用了以下 SQL:
SELECT datasetstatusID from datasetstatus where DatasetID = meta_dataset
但是你应该改用 HQL:
from datasetstatus d where d.datasetID = meta_dataset
这是您修改后的代码:
String q1 = "from datasetstatus d where d.datasetID = :datasetID";
Query query = session.createSQLQuery(q1)
.setParameter("datasetID", meta_dataset);
List<Datasetstatus> dobj = query.list();
for (Datasetstatus dobj1 : dobj) {
System.out.println("Value :: " + dobj1.getDatasetStatusId());
}
您需要将查询更改为:
List<Integer> dobj=
(List<Integer>) session.createSQLQuery(
"SELECT ds.datasetstatusID " +
"from datasetstatus ds " +
"where ds.datasetId = :dataSetId")
.setParameter("dataSetId", meta_dataset)
.list();
datasetstatusID
是一个整数而不是 Datasetstatus
。
如果您想 return Datasetstatus
,您的查询将是:
List<Datasetstatus> dobj=
(List<Datasetstatus>) session.createSQLQuery(
"SELECT ds " +
"from datasetstatus ds " +
"where ds.datasetId = :dataSetId")
.setParameter("dataSetId", meta_dataset)
.list();
您正在从 pojo class 访问特定属性而不是 pojo 对象,那么只有您面对 java.lang.Integer cannot be cast to pojo.Datasetstatus
您可以尝试,
String q1="SELECT a from datasetstatus as a whereDatasetID='"+meta_dataset+"'";
Query query=session.createQuery(q1);
List<Datasetstatus> dobj=(List<Datasetstatus>) query.list();
for(Datasetstatus dobj1: dobj) {
System.out.println("Value :: "+dobj1.getDatasetStatusId());
}
如果您尝试上面的代码,您将得到答案。或者你也可以试试下面的代码,
String q1="SELECT a.datasetstatusID from datasetstatus as a whereDatasetID='"+meta_dataset+"'";
Query query=session.createSQLQuery(q1);
List<Object[]> dobj=query.list();
for(Object dobj1: dobj) {
System.out.println("Value :: "+dobj1.get[0]);
}
如果您正在检索单列值,那么理想情况下您不应该使用 POJO Class 而不是您可以直接将其转换为 List
List<Integer> dobj = query.list();
for(Integer dobj1: dobj) {
System.out.println("Value :: "+dobj1);
}
这将解决您的问题
正在使用 Hibernate 从 table 中检索整数值,发生以下异常,
java.lang.ClassCastException: java.lang.Integer cannot be cast to pojo.Datasetstatus
String q1="SELECT datasetstatusID from datasetstatus where DatasetID='"+meta_dataset+"'";
Query query=session.createSQLQuery(q1);
List<Datasetstatus> dobj=query.list();
for(Datasetstatus dobj1: dobj) {
System.out.println("Value :: "+dobj1.getDatasetStatusId());
}
Pojo class 格式,
public class Datasetstatus implements java.io.Serializable {
private Integer datasetStatusId;
private String datasetId;
public Datasetstatus(String datasetId) {
this.datasetId = datasetId;
}
public Integer getDatasetStatusId() {
return this.datasetStatusId;
}
public void setDatasetStatusId(Integer datasetStatusId) {
this.datasetStatusId = datasetStatusId;
}
public String getDatasetId() {
return this.datasetId;
}
public void setDatasetId(String datasetId) {
this.datasetId = datasetId;
}
}
如果有解决这个问题的建议
您的查询似乎有问题。您使用了以下 SQL:
SELECT datasetstatusID from datasetstatus where DatasetID = meta_dataset
但是你应该改用 HQL:
from datasetstatus d where d.datasetID = meta_dataset
这是您修改后的代码:
String q1 = "from datasetstatus d where d.datasetID = :datasetID";
Query query = session.createSQLQuery(q1)
.setParameter("datasetID", meta_dataset);
List<Datasetstatus> dobj = query.list();
for (Datasetstatus dobj1 : dobj) {
System.out.println("Value :: " + dobj1.getDatasetStatusId());
}
您需要将查询更改为:
List<Integer> dobj=
(List<Integer>) session.createSQLQuery(
"SELECT ds.datasetstatusID " +
"from datasetstatus ds " +
"where ds.datasetId = :dataSetId")
.setParameter("dataSetId", meta_dataset)
.list();
datasetstatusID
是一个整数而不是 Datasetstatus
。
如果您想 return Datasetstatus
,您的查询将是:
List<Datasetstatus> dobj=
(List<Datasetstatus>) session.createSQLQuery(
"SELECT ds " +
"from datasetstatus ds " +
"where ds.datasetId = :dataSetId")
.setParameter("dataSetId", meta_dataset)
.list();
您正在从 pojo class 访问特定属性而不是 pojo 对象,那么只有您面对 java.lang.Integer cannot be cast to pojo.Datasetstatus
您可以尝试,
String q1="SELECT a from datasetstatus as a whereDatasetID='"+meta_dataset+"'";
Query query=session.createQuery(q1);
List<Datasetstatus> dobj=(List<Datasetstatus>) query.list();
for(Datasetstatus dobj1: dobj) {
System.out.println("Value :: "+dobj1.getDatasetStatusId());
}
如果您尝试上面的代码,您将得到答案。或者你也可以试试下面的代码,
String q1="SELECT a.datasetstatusID from datasetstatus as a whereDatasetID='"+meta_dataset+"'";
Query query=session.createSQLQuery(q1);
List<Object[]> dobj=query.list();
for(Object dobj1: dobj) {
System.out.println("Value :: "+dobj1.get[0]);
}
如果您正在检索单列值,那么理想情况下您不应该使用 POJO Class 而不是您可以直接将其转换为 List
List<Integer> dobj = query.list();
for(Integer dobj1: dobj) {
System.out.println("Value :: "+dobj1);
}
这将解决您的问题