как начать с "0" неподписанного поля AUTO_INCREMENT? - PullRequest
1 голос
/ 14 марта 2012

У меня есть следующие таблицы: enter image description here

enter image description here

, где idclient равно unsigned auto_increment.

код объекта клиента:

import java.io.Serializable;

import java.util.List;

import javax.persistence.*;

import javax.xml.bind.annotation.XmlRootElement;

import javax.xml.bind.annotation.XmlTransient;


@Entity
@Table(name = "CLIENT", catalog = "TEST", schema = "PUBLIC")
@XmlRootElement
@NamedQueries({
@NamedQuery(name = "Client.findAll", query = "SELECT c FROM Client c"),
@NamedQuery(name = "Client.findByIdclient", query = "SELECT c FROM Client c WHERE c.idclient = :idclient"),
@NamedQuery(name = "Client.findByLibel", query = "SELECT c FROM Client c WHERE c.libel = :libel"),
@NamedQuery(name = "Client.findByAdresse", query = "SELECT c FROM Client c WHERE c.adresse = :adresse"),
@NamedQuery(name = "Client.findByNomResp", query = "SELECT c FROM Client c WHERE c.nomResp = :nomResp"),
@NamedQuery(name = "Client.findByTelPortable", query = "SELECT c FROM Client c WHERE c.telPortable = :telPortable"),
@NamedQuery(name = "Client.findByTelFixe", query = "SELECT c FROM Client c WHERE c.telFixe = :telFixe"),
@NamedQuery(name = "Client.findByFax", query = "SELECT c FROM Client c WHERE c.fax = :fax"),
@NamedQuery(name = "Client.findByCodeTva", query = "SELECT c FROM Client c WHERE c.codeTva = :codeTva"),
@NamedQuery(name = "Client.findByCodeExo", query = "SELECT c FROM Client c WHERE c.codeExo = :codeExo"),
@NamedQuery(name = "Client.findByBanque", query = "SELECT c FROM Client c WHERE c.banque = :banque"),
@NamedQuery(name = "Client.findByRib", query = "SELECT c FROM Client c WHERE c.rib = :rib"),
@NamedQuery(name = "Client.findByCredit", query = "SELECT c FROM Client c WHERE c.credit = :credit"),
@NamedQuery(name = "Client.findByEchance", query = "SELECT c FROM Client c WHERE c.echance = :echance"),
@NamedQuery(name = "Client.findByMail", query = "SELECT c FROM Client c WHERE c.mail = :mail"),
@NamedQuery(name = "Client.findByEtat", query = "SELECT c FROM Client c WHERE c.etat = :etat")})
public class Client implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Basic(optional = false)
@Column(name = "IDCLIENT", nullable = false)
private Integer idclient;
@Basic(optional = false)
@Column(name = "LIBEL", nullable = false, length = 100)
private String libel;
@Basic(optional = false)
@Column(name = "ADRESSE", nullable = false, length = 100)
private String adresse;
@Basic(optional = false)
@Column(name = "NOM_RESP", nullable = false, length = 60)
private String nomResp;
@Basic(optional = false)
@Column(name = "TEL_PORTABLE", nullable = false, length = 16)
private String telPortable;
@Basic(optional = false)
@Column(name = "TEL_FIXE", nullable = false, length = 16)
private String telFixe;
@Basic(optional = false)
@Column(name = "FAX", nullable = false, length = 16)
private String fax;
@Basic(optional = false)
@Column(name = "CODE_TVA", nullable = false, length = 30)
private String codeTva;
@Basic(optional = false)
@Column(name = "CODE_EXO", nullable = false, length = 30)
private String codeExo;
@Basic(optional = false)
@Column(name = "BANQUE", nullable = false, length = 60)
private String banque;
@Basic(optional = false)
@Column(name = "RIB", nullable = false, length = 22)
private String rib;
@Basic(optional = false)
@Column(name = "CREDIT", nullable = false)
private double credit;
@Basic(optional = false)
@Column(name = "ECHANCE", nullable = false)
private int echance;
@Basic(optional = false)
@Column(name = "MAIL", nullable = false, length = 70)
private String mail;
@Basic(optional = false)
@Column(name = "ETAT", nullable = false)
private char etat;
@OneToMany(cascade = CascadeType.ALL, mappedBy = "clientIdclient")
private List<Facture> factureList;
@OneToMany(cascade = CascadeType.ALL, mappedBy = "clientIdclient")
private List<FactProforma> factProformaList;
@OneToMany(cascade = CascadeType.ALL, mappedBy = "clientIdclient")
private List<Bl> blList;

public Client() {
}

public Client(Integer idclient) {
    this.idclient = idclient;
}

public Client(Integer idclient, String libel, String adresse, String nomResp, String telPortable, String telFixe, String fax, String codeTva, String codeExo, String banque, String rib, double credit, int echance, String mail, char etat) {
    this.idclient = idclient;
    this.libel = libel;
    this.adresse = adresse;
    this.nomResp = nomResp;
    this.telPortable = telPortable;
    this.telFixe = telFixe;
    this.fax = fax;
    this.codeTva = codeTva;
    this.codeExo = codeExo;
    this.banque = banque;
    this.rib = rib;
    this.credit = credit;
    this.echance = echance;
    this.mail = mail;
    this.etat = etat;
}

public Integer getIdclient() {
    return idclient;
}

public void setIdclient(Integer idclient) {
    this.idclient = idclient;
}

public String getLibel() {
    return libel;
}

public void setLibel(String libel) {
    this.libel = libel;
}

public String getAdresse() {
    return adresse;
}

public void setAdresse(String adresse) {
    this.adresse = adresse;
}

public String getNomResp() {
    return nomResp;
}

public void setNomResp(String nomResp) {
    this.nomResp = nomResp;
}

public String getTelPortable() {
    return telPortable;
}

public void setTelPortable(String telPortable) {
    this.telPortable = telPortable;
}

public String getTelFixe() {
    return telFixe;
}

public void setTelFixe(String telFixe) {
    this.telFixe = telFixe;
}

public String getFax() {
    return fax;
}

public void setFax(String fax) {
    this.fax = fax;
}

public String getCodeTva() {
    return codeTva;
}

public void setCodeTva(String codeTva) {
    this.codeTva = codeTva;
}

public String getCodeExo() {
    return codeExo;
}

public void setCodeExo(String codeExo) {
    this.codeExo = codeExo;
}

public String getBanque() {
    return banque;
}

public void setBanque(String banque) {
    this.banque = banque;
}

public String getRib() {
    return rib;
}

public void setRib(String rib) {
    this.rib = rib;
}

public double getCredit() {
    return credit;
}

public void setCredit(double credit) {
    this.credit = credit;
}

public int getEchance() {
    return echance;
}

public void setEchance(int echance) {
    this.echance = echance;
}

public String getMail() {
    return mail;
}

public void setMail(String mail) {
    this.mail = mail;
}

public char getEtat() {
    return etat;
}

public void setEtat(char etat) {
    this.etat = etat;
}

@XmlTransient
public List<Facture> getFactureList() {
    return factureList;
}

public void setFactureList(List<Facture> factureList) {
    this.factureList = factureList;
}

@XmlTransient
public List<FactProforma> getFactProformaList() {
    return factProformaList;
}

public void setFactProformaList(List<FactProforma> factProformaList) {
    this.factProformaList = factProformaList;
}

@XmlTransient
public List<Bl> getBlList() {
    return blList;
}

public void setBlList(List<Bl> blList) {
    this.blList = blList;
}

@Override
public int hashCode() {
    int hash = 0;
    hash += (idclient != null ? idclient.hashCode() : 0);
    return hash;
}

@Override
public boolean equals(Object object) {
    // TODO: Warning - this method won't work in the case the id fields are not set
    if (!(object instanceof Client)) {
        return false;
    }
    Client other = (Client) object;
    if ((this.idclient == null && other.idclient != null) || (this.idclient != null && !this.idclient.equals(other.idclient))) {
        return false;
    }
    return true;
}

@Override
public String toString() {
    return "glob.entitys.Client[ idclient=" + idclient + " ]";
  }

}

, когда я пытаюсь вставить строку в базу данных:

Utilisateur user=new Utilisateur(loginActuel);
Client client=new Client(0);// the error comes from here
Facture fact=new Facture(null,new Date());
fact.setClientIdclient(client);
fact.setUtilisateurLogin(user);
FactureJpaController fjc=new FactureJpaController(emf);
fjc.create(fact);

Я получаю эту ужасную ошибку (но когда я установил new Client(1), она работает хорошо):

Exception in thread "AWT-EventQueue-0" javax.persistence.RollbackException: Exception [EclipseLink-7197] (Eclipse Persistence Services - 2.3.0.v20110604-r9504): org.eclipse.persistence.exceptions.ValidationException

Exception Description: Null or zero primary key encountered in unit of work clone [glob.entitys.Client[ idclient=0 ]], primary key [0]. Set descriptors IdValidation or the "eclipselink.id-validation" property.

как решить эту проблему?

примечание : клиентский idclient = 0 уже вставлен в базу данных (но вручную), я хотел бы один раз и длявсе преодолевают эту «проблему», как предотвратить запуск базы данных JPA или H2 с 0?

Ответы [ 5 ]

2 голосов
/ 03 апреля 2013

Есть два способа разрешить нули в первичных ключах в Eclipselink:

Параметр в persistence.xml:

<property name="eclipselink.id-validation" value="NULL"/>

PrimaryKey аннотация к соответствующему классу сущностей:

@PrimaryKey(validation = IdValidation.NULL)
2 голосов
/ 14 марта 2012

H2 позволяет использовать 0 в качестве первичного ключа. Сообщение об ошибке не приходит от H2.

Однако мне кажется, что некоторые (более старые?) Версии EclipseLink не позволяют использовать 0.

идентификатор клиента = 0 уже вставлен в базу данных

Кажется, это не поддерживается этой версией EclipseLink. Похоже, чтобы обойти эту проблему, вы не должны использовать значение 0.

1 голос
/ 26 сентября 2012

Документы говорят

По умолчанию EclipseLink интерпретирует ноль как ноль для примитивных типов, которые не могут быть нулевыми (например, int и long), в результате чего ноль является недопустимым значением для первичных ключей.

но также и то, что это поведение можно изменить либо в persistence.xml, либо в конкретной сущности.

http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Basic_JPA_Development/Entities/Ids/Id#Allowing_Zero_Value_Primary_Keys

1 голос
/ 29 мая 2012

У меня была эта ошибка, и добавление следующих аннотаций к моей идентификации jpa устранило ее:

  @Column(name = "ID_SEARCH_LOG", nullable = false, insertable = true, updatable = true, length = 10, precision = 0)
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private int idSearchLog;
1 голос
/ 15 марта 2012

Для JPA (спецификация 2.0), имеющей (или отрицательное) значение для id, вполне подойдет.А также в качестве значения первичного ключа для H2.

В старых версиях EclipseLink значение 0 или меньше считается недействительным первичным ключом.Смотрите, например, следующее: Ошибка 249948 .Так что обновление EclipseLink может помочь.

Кстати, почему вы устанавливаете в конструкторе значение для idclient, который должен генерироваться?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...