为类classname提供了错误类型的id Expected:class java.lang.Integer,get class java.lang.String

时间:2016-08-15 07:23:42

标签: hibernate primary-key

这是我的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

1 个答案:

答案 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);