Java JPA将列的值增加1

Java JPA将列的值增加1,java,mysql,hibernate,jpa,spring-data-jpa,Java,Mysql,Hibernate,Jpa,Spring Data Jpa,我试图实现一个自动增加“version”列值的DAO。版本不是主密钥。问题是,我以前尝试过“@GeneratedValue”值,但它不起作用,sql给出了一条消息,这只允许primarykey列使用,因此我不得不使用lastUpdate值并将其增加一个值,但这不起作用,并且它一直传递1作为插入值 这是我的密码: @Repository public class VersionDAO { @PersistenceContext private EntityManager em;

我试图实现一个自动增加“version”列值的DAO。版本不是主密钥。问题是,我以前尝试过“@GeneratedValue”值,但它不起作用,sql给出了一条消息,这只允许primarykey列使用,因此我不得不使用lastUpdate值并将其增加一个值,但这不起作用,并且它一直传递1作为插入值

这是我的密码:

@Repository
public class VersionDAO {

    @PersistenceContext
    private EntityManager em;

    public void create(Version version) {
        Version lastUpdate = (Version) em.createQuery("SELECT c FROM Version c ORDER BY c.uploadedtimestamp DESC")//
        .setMaxResults(1).getResultList();
        int ver = lastUpdate.getVersion() + 1;
        version.setVersion(ver);

        em.persist(version);
    }

    public void delete(Version version) {
        em.remove(version);
    }
}

@Entity
@Table(name = "version")
public class Version implements Serializable {
    private static final long serialVersionUID = 1L;

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "id")
    private Integer id;


    @Column(name = "version")   
    private Integer version;

    @Column(name="uploadedtimestamp")
    @Temporal(TemporalType.TIMESTAMP)
    private Date uploadedtimestamp = new Date();        

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public Integer getVersion() {
        return version;
    }

    public void setVersion(Integer version) {
        this.version = version;
    }

    @Override
    public boolean equals(Object obj) {
        if (obj == null) {
            return false;
        }
        if (obj == this) {
            return true;
        }
        if (obj.getClass() != getClass()) {
            return false;
        }
        Version cdi = (Version) obj;
        return new EqualsBuilder().append(getId(), cdi.getId()).isEquals();
    }

    @Override
    public int hashCode() {
        return new HashCodeBuilder(17, 37).append(getId()).toHashCode();
    }

    public Date getUploadedtimestamp() {
        return uploadedtimestamp;
    }

    public void setUploadedtimestamp(Date uploadedtimestamp) {
        this.uploadedtimestamp = uploadedtimestamp;
    }
}

尝试选择最大版本,并更新值+1

public void incrementVersion() {
        Version lastUpdate = (Version) em.createQuery("SELECT max (c.version) FROM X c")          .setMaxResults(1).getResultList();
        int ver = lastUpdate.getVersion() + 1;
        lastUpdate.setVersion(ver);

        em.persist(lastUpdate);
    }

尝试选择最大版本,并更新值+1

public void incrementVersion() {
        Version lastUpdate = (Version) em.createQuery("SELECT max (c.version) FROM X c")          .setMaxResults(1).getResultList();
        int ver = lastUpdate.getVersion() + 1;
        lastUpdate.setVersion(ver);

        em.persist(lastUpdate);
    }

尝试选择最大版本,并更新值+1

public void incrementVersion() {
        Version lastUpdate = (Version) em.createQuery("SELECT max (c.version) FROM X c")          .setMaxResults(1).getResultList();
        int ver = lastUpdate.getVersion() + 1;
        lastUpdate.setVersion(ver);

        em.persist(lastUpdate);
    }

尝试选择最大版本,并更新值+1

public void incrementVersion() {
        Version lastUpdate = (Version) em.createQuery("SELECT max (c.version) FROM X c")          .setMaxResults(1).getResultList();
        int ver = lastUpdate.getVersion() + 1;
        lastUpdate.setVersion(ver);

        em.persist(lastUpdate);
    }

我认为你不应该通过JPA来处理这件事。您可以为表创建触发器,以便在每次更新行时自动增加“版本”值

例如,如果您使用的是MySQL:

CREATE TRIGGER version_trigger BEFORE UPDATE ON `your_table`
FOR EACH ROW
SET NEW.version = (OLD.version + 1)

我认为你不应该通过JPA来处理这件事。您可以为表创建触发器,以便在每次更新行时自动增加“版本”值

例如,如果您使用的是MySQL:

CREATE TRIGGER version_trigger BEFORE UPDATE ON `your_table`
FOR EACH ROW
SET NEW.version = (OLD.version + 1)

我认为你不应该通过JPA来处理这件事。您可以为表创建触发器,以便在每次更新行时自动增加“版本”值

例如,如果您使用的是MySQL:

CREATE TRIGGER version_trigger BEFORE UPDATE ON `your_table`
FOR EACH ROW
SET NEW.version = (OLD.version + 1)

我认为你不应该通过JPA来处理这件事。您可以为表创建触发器,以便在每次更新行时自动增加“版本”值

例如,如果您使用的是MySQL:

CREATE TRIGGER version_trigger BEFORE UPDATE ON `your_table`
FOR EACH ROW
SET NEW.version = (OLD.version + 1)

在JPA2.0中有
@版本
注释

您只需将注释添加到要作为版本字段的字段中,如下所示:

@Entity
public class MyEntity implements Serializable {    

    @Id
    @GeneratedValue
    private Long id;

    private String name;

    @Version
    private Long version;

    //...
}

请看:

在JPA2.0中有
@版本的
注释

您只需将注释添加到要作为版本字段的字段中,如下所示:

@Entity
public class MyEntity implements Serializable {    

    @Id
    @GeneratedValue
    private Long id;

    private String name;

    @Version
    private Long version;

    //...
}

请看:

在JPA2.0中有
@版本的
注释

您只需将注释添加到要作为版本字段的字段中,如下所示:

@Entity
public class MyEntity implements Serializable {    

    @Id
    @GeneratedValue
    private Long id;

    private String name;

    @Version
    private Long version;

    //...
}

请看:

在JPA2.0中有
@版本的
注释

您只需将注释添加到要作为版本字段的字段中,如下所示:

@Entity
public class MyEntity implements Serializable {    

    @Id
    @GeneratedValue
    private Long id;

    private String name;

    @Version
    private Long version;

    //...
}


看看:

我想你想要什么还不清楚。是什么东西[.更新实体时的版本?否版本名称用于其他内容。我只想将其值加1,每次有新的插入项时,您尝试更新名为version的字段或尝试创建具有递增版本的新对象我只想更新名为version的字段version@user261002您使用的是哪种数据库管理系统ysql,SQL Server,还有什么?我想还不清楚你想要什么。是这样的吗[.更新实体时的版本?否版本名称用于其他内容。我只想将其值加1,每次有新的插入项时,您尝试更新名为version的字段或尝试创建具有递增版本的新对象我只想更新名为version的字段version@user261002您使用的是哪种数据库管理系统ysql,SQL Server,还有什么?我想还不清楚你想要什么。是这样的吗[.更新实体时的版本?否版本名称用于其他内容。我只想将其值加1,每次有新的插入项时,您尝试更新名为version的字段或尝试创建具有递增版本的新对象我只想更新名为version的字段version@user261002您使用的是哪种数据库管理系统ysql,SQL Server,还有什么?我想还不清楚你想要什么。是这样的吗[.更新实体时的版本?否版本名称用于其他内容。我只想将其值加1,每次有新的插入项时,您尝试更新名为version的字段或尝试创建具有递增版本的新对象我只想更新名为version的字段version@user261002您使用的是哪种数据库管理系统ysql,SQL Server,还有什么?这不是一个有效的答案,因为它不使用JPA作为OP ASQUEST,并且打破了JPA数据库不可知论的概念。这不是一个有效的答案,因为它不使用JPA作为OP ASQUEST,并且打破了JPA数据库不可知论的概念。这不是一个有效的答案,因为它不使用JPA作为OP ASQUEST和b破解jpa数据库不可知论的概念这不是一个有效的答案,因为它没有使用jpa作为OP提问,并且有点打破了jpa数据库不可知论的概念