这是我的sql表格描述
desc product_details;
+--------------------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------------------+-------------+------+-----+---------+-------+
| action | varchar(5) | YES | | NULL | |
| version | varchar(2) | YES | | NULL | |
| productCatalogName | varchar(50) | YES | | NULL | |
| productId | varchar(25) | NO | | NULL | |
| price | varchar(10) | NO | | NULL | |
| Operator_Code | varchar(7) | YES | | NULL | |
| product_name | varchar(70) | YES | | NULL | |
| subs_id | int(11) | NO | PRI | 0 | |
+--------------------+-------------+------+-----+---------+-------+
每当我调用get方法时
ProductDetail productDetail = (ProductDetail )session.get(ProductDetail .class, subs_id);
我得到例外:
nested exception is org.hibernate.TypeMismatchException: Provided id of the wrong type for class tpay.table.ProductDetail. Expected: class java.lang.Integer, got class java.lang.String
package tpay.table;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Table;
@Entity
@Table(name="product_details")
public class ProductDetail {
@Id
@Column(name="subs_id")
int subs_id;
@Column(name="action")
String action;
@Column(name="version")
String version;
@Column(name="productCatalogName")
String productCatalogName;
@Column(name="productId")
String productId;
@Column(name="price")
String price;
@Column(name="Operator_Code")
String Operator_Code;
@Column(name="product_name")
String product_name;
public String getAction() {
return action;
}
public void setAction(String action) {
this.action = action;
}
public String getVersion() {
return version;
}
public void setVersion(String version) {
this.version = version;
}
public String getProductCatalogName() {
return productCatalogName;
}
public void setProductCatalogName(String productCatalogName) {
this.productCatalogName = productCatalogName;
}
public String getProductId() {
return productId;
}
public void setProductId(String productId) {
this.productId = productId;
}
public String getPrice() {
return price;
}
public void setPrice(String price) {
this.price = price;
}
public String getOperator_Code() {
return Operator_Code;
}
public void setOperator_Code(String operator_Code) {
Operator_Code = operator_Code;
}
public String getProduct_name() {
return product_name;
}
public void setProduct_name(String product_name) {
this.product_name = product_name;
}
public int getSubs_id() {
return subs_id;
}
public void setSubs_id(int subs_id) {
this.subs_id = subs_id;
}
}
如您所见,我已经使用int变量作为主键subs_id 那为什么它给予例外 为类tpay.table.ProductDetail提供了错误类型的id。预期:类java.lang.Integer,得到类java.lang.String
答案 0 :(得分:3)
给session.get的id类型是错误的。正如错误消息所述,在期望Integer时给出了String:
预期:类java.lang.Integer,得到类java.lang.String
以下代码发生此类错误:
navigationController?.delegate = self
使用此代码类型是正确的,不会发生错误:
String subs_id = "1";
ProductDetail productDetail = (ProductDetail )
session.get(ProductDetail .class, subs_id);