没有主键的表,hibernate怎么去update

本文介绍了一种在Hibernate中使用复合主键的方法。通过创建一个嵌套的复合主键类并将其作为实体的一部分,可以有效地解决更新操作时的唯一性问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

有一个表,没有设置主键,又想update,怎么办?

 

发现这个表其实是可以有复合主键的,但是database里没有设置,而hibernate写annotation的时候又一定要设置主键@Id,如果你只设置一个,在update的时候会报错,因为一个键不是唯一,但是设置两个,hibernate又不允许。

用嵌套吧。

 



import java.io.Serializable;

import javax.persistence.Column;
import javax.persistence.Embeddable;
import javax.persistence.EmbeddedId;
import javax.persistence.Entity;
import javax.persistence.Table;

import com.thoughtworks.xstream.annotations.XStreamAlias;

@Entity
@Table(name = "tbl_user_download_buy_list")
public class UserDownloadBuyListVO implements Serializable {

    /**
     *
     */
    private static final long serialVersionUID = 1L;

    private DownloadbuyListPK dpk = new DownloadbuyListPK();

    private Long downloadStatusID;
    private String downloadAuthKey;
    private String EncDRMKey;
    private Long subscriptionID;
   

    @Column(name = "DOWNLOAD_STATUS_ID", nullable = false, length = 20)
    public Long getDownloadStatusID() {
        return downloadStatusID;
    }

    public void setDownloadStatusID(Long downloadStatusID) {
        this.downloadStatusID = downloadStatusID;
    }

    @Column(name = "DOWNLOAD_AUTH_KEY", nullable = false, length = 32)
    public String getDownloadAuthKey() {
        return downloadAuthKey;
    }

    public void setDownloadAuthKey(String downloadAuthKey) {
        this.downloadAuthKey = downloadAuthKey;
    }

    @Column(name = "ENCRYPTED_DRM_KEY", nullable = false, length = 45)
    public String getEncDRMKey() {
        return EncDRMKey;
    }

    public void setEncDRMKey(String encDRMKey) {
        EncDRMKey = encDRMKey;
    }

    @Column(name = "SUBSCRIPTION_ID", nullable = true, length = 45)
    public Long getSubscriptionID() {
        return subscriptionID;
    }

    public void setSubscriptionID(Long subscriptionID) {
        this.subscriptionID = subscriptionID;
    }



    @EmbeddedId
    public DownloadbuyListPK getDpk() {
        return dpk;
    }

    public void setDpk(DownloadbuyListPK dpk) {
        this.dpk = dpk;
    }




    @Embeddable
    public static class DownloadbuyListPK implements Serializable {

        /**
         *
         */
        private static final long serialVersionUID = 1L;

        public DownloadbuyListPK() {
            super();
        }

        private String userUID;
        private String publishedPackageUID;
       
        @Column(name = "USER_UID", nullable = false, length = 32)
        public String getUserUID() {
            return userUID;
        }

        public void setUserUID(String userUID) {
            this.userUID = userUID;
        }

        @Column(name = "PUBLICATION_PACKAGE_UID", nullable = false, length = 32)
        public String getPublishedPackageUID() {
            return publishedPackageUID;
        }

        public void setPublishedPackageUID(String publishedPackageUID) {
            this.publishedPackageUID = publishedPackageUID;
        }

        @Override
        public int hashCode() {
            final int prime = 31;
            int result = 1;
            result = prime * result ;
            result = prime
                    * result
                    + ((publishedPackageUID == null) ? 0 : publishedPackageUID
                            .hashCode());
            result = prime * result
                    + ((userUID == null) ? 0 : userUID.hashCode());
            return result;
        }

        @Override
        public boolean equals(Object obj) {
            if (this == obj)
                return true;
            if (obj == null)
                return false;
            if (getClass() != obj.getClass())
                return false;
            DownloadbuyListPK other = (DownloadbuyListPK) obj;
            if (publishedPackageUID == null) {
                if (other.publishedPackageUID != null)
                    return false;
            } else if (!publishedPackageUID.equals(other.publishedPackageUID))
                return false;
            if (userUID == null) {
                if (other.userUID != null)
                    return false;
            } else if (!userUID.equals(other.userUID))
                return false;
            return true;
        }

       

    }

}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值