IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Hibernate Java Discussion :

[Hibernate] exception entre MySQL et MS SQL


Sujet :

Hibernate Java

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Septembre 2005
    Messages
    504
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2005
    Messages : 504
    Points : 288
    Points
    288
    Par défaut [Hibernate] exception entre MySQL et MS SQL
    Bonjour,
    j'ai créer une base de données MySQL (via EasyPhp), et j'insere via un session.persist() un objet qui par cascade sauvegarde toute une structure... jusque là tout va bien
    Maintenant que cela marche bien sur MySQL, je répété ce schéma sur MS SQL, je change le fichier de config avec celui qui va bien.
    Et là c'est le drame, la même manip me provoque une exception !!

    que voici :

    org.hibernate.exception.ConstraintViolationException: could not insert: [dsi.emc.pac7000.core.persistence.DatabaseManager]
    at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:63)
    at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:43)
    at org.hibernate.persister.entity.BasicEntityPersister.insert(BasicEntityPersister.java:1777)
    at org.hibernate.action.EntityIdentityInsertAction.execute(EntityIdentityInsertAction.java:34)
    at org.hibernate.engine.ActionQueue.execute(ActionQueue.java:239)
    at org.hibernate.event.def.AbstractSaveEventListener.performSaveOrReplicate(AbstractSaveEventListener.java:240)
    at org.hibernate.event.def.AbstractSaveEventListener.performSave(AbstractSaveEventListener.java:160)
    at org.hibernate.event.def.AbstractSaveEventListener.saveWithGeneratedId(AbstractSaveEventListener.java:95)
    at org.hibernate.event.def.DefaultPersistEventListener.entityIsTransient(DefaultPersistEventListener.java:124)
    org.hibernate.event.def.DefaultPersistEventListener.onPersist(DefaultPersistEventListener.java:38)
    at org.hibernate.impl.SessionImpl.persist(SessionImpl.java:529)
    ....
    Caused by: java.sql.SQLException: Impossible d'insérer la valeur NULL dans la colonne 'workspace_uid', table 'PAC7000_1.dbo.WORKSPACE'. Cette colonne n'accepte pas les valeurs NULL. INSERT a échoué.
    at net.sourceforge.jtds.jdbc.SQLDiagnostic.addDiagnostic(SQLDiagnostic.java:364)
    at net.sourceforge.jtds.jdbc.TdsCore.tdsErrorToken(TdsCore.java:2754)
    at net.sourceforge.jtds.jdbc.TdsCore.nextToken(TdsCore.java:2195)
    at net.sourceforge.jtds.jdbc.TdsCore.getMoreResults(TdsCore.java:620)
    at net.sourceforge.jtds.jdbc.JtdsStatement.processResults(JtdsStatement.java:483)
    at net.sourceforge.jtds.jdbc.JtdsStatement.executeSQL(JtdsStatement.java:445)
    at net.sourceforge.jtds.jdbc.JtdsPreparedStatement.executeUpdate(JtdsPreparedStatement.java:402)
    at org.hibernate.persister.entity.BasicEntityPersister.insert(BasicEntityPersister.java:1759)
    ... 41 more


    je ne comprends pas pourquoi sur l'un cela marche et pas sur l'autre... il y a peut etre un privilege que je n'ai pas en tant qu'utilisateur.

    SI quelqu'un voit d'ou cela peu venir...
    merci d'avance

  2. #2
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    274
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 274
    Points : 307
    Points
    307
    Par défaut
    bonjour,

    la réponse est dans la trace
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Impossible d'insérer la valeur NULL dans la colonne 'workspace_uid', table 'PAC7000_1.dbo.WORKSPACE'. Cette colonne n'accepte pas les valeurs NULL. INSERT a échoué.
    NOT NULL est facultatif, puisque par défaut, dans SQL Server et je suppose que cela n'est pas le cas dans mysql.

    il te faut changer la définition de ta colonne

  3. #3
    Membre actif
    Profil pro
    Inscrit en
    Septembre 2005
    Messages
    504
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2005
    Messages : 504
    Points : 288
    Points
    288
    Par défaut
    merci, voici mon fichier XML de workSpace :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
     
     <class name="WorkSpace" table="WORKSPACE" discriminator-value="W">
     <id name="id" column="workspace_uid" type="long" unsaved-value="null">
      <generator class="native" /> 
      </id>
      <discriminator column="WORKSPACE_TYPE" type="string"/> 
     <bag name="rights" cascade="persist,save-update,delete-orphan" inverse="false">
      <key column="workspace_uid"/> 
      <one-to-many class="dsi.emc.pac7000.core.identification.Right"/> 
      </bag>
     <subclass name="DatabaseManager" discriminator-value="DATABASEMANAGER" dynamic-update="false" dynamic-insert="false" select-before-update="false">
     <bag name="databases" inverse="false" cascade="persist,save-update" mutable="true" optimistic-lock="true" embed-xml="true">
      <key column="databasemanager_uid" on-delete="noaction" /> 
      <one-to-many class="Database" not-found="exception" embed-xml="true" /> 
      </bag>
      </subclass>
     <subclass name="HardDisk" discriminator-value="HARDDISK" dynamic-update="false" dynamic-insert="false" select-before-update="false">
      <property name="gageFileKey" column="GAGE_FILE_KEY" type="int" unique="false" optimistic-lock="true" lazy="false" generated="never" /> 
      </subclass>
      </class>
      </hibernate-mapping>
    donc a priori je dois changer les lignes:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
     <id name="id" column="workspace_uid" type="long" unsaved-value="null">
    il suufit que je mette not-null?

  4. #4
    Membre averti
    Inscrit en
    Août 2005
    Messages
    352
    Détails du profil
    Informations forums :
    Inscription : Août 2005
    Messages : 352
    Points : 427
    Points
    427
    Par défaut
    Tu as déjà vu une clé primaire nulle ? Pas moi, ton mapping ne peut pas être utilisé parceque native n'est pas utilisable pour SQL Server (je pense).
    native est un generator qui utilise un mécanisme interne à la base, dans le cas de MySQL, un champ qui s'auto-incrémente.
    Pour une compatibilité entre les 2 bases, je te conseille d'utiliser identity, hilo, seqhilo, uuid ou guid.

    http://www.hibernate.org/hib_docs/v3/reference/fr/html_single/#mapping-declaration-id-generator

  5. #5
    Membre actif
    Profil pro
    Inscrit en
    Septembre 2005
    Messages
    504
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2005
    Messages : 504
    Points : 288
    Points
    288
    Par défaut
    j'ai testé avec le generator native, et j'ai le meme pb... voici ce que j'ai changé:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
                    <id name="id" column="workspace_uid" type="long" unsaved-value="0">
                            <generator class="identity"/>
                    </id>
    mais le truc bizarre c'est que je ne comprends pas pourquoi il veut insérer nulle dans cette colonne... en tout cas j'ai toujours la même exception

  6. #6
    Membre habitué
    Inscrit en
    Septembre 2003
    Messages
    174
    Détails du profil
    Informations forums :
    Inscription : Septembre 2003
    Messages : 174
    Points : 194
    Points
    194
    Par défaut
    Citation Envoyé par dlemoing
    Tu as déjà vu une clé primaire nulle ? Pas moi, ton mapping ne peut pas être utilisé parceque native n'est pas utilisable pour SQL Server (je pense).
    native est un generator qui utilise un mécanisme interne à la base, dans le cas de MySQL, un champ qui s'auto-incrémente.
    Pour une compatibilité entre les 2 bases, je te conseille d'utiliser identity, hilo, seqhilo, uuid ou guid.

    http://www.hibernate.org/hib_docs/v3/reference/fr/html_single/#mapping-declaration-id-generator
    identity est supporté par SQL Server, donc a priori native est utilisable dans le cas d'une base SQL Server

    Dans ton cas, la violation de la contrainte peut-être à deux niveaux :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <id name="id" column="workspace_uid" type="long" unsaved-value="null"> -
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    <bag name="rights" cascade="persist,save-update,delete-orphan" inverse="false"> 
      <key column="workspace_uid"/>
    Tu pourrais peut-etre (à titre d'essai), changer le nom de la cléf étrangère pour "rights" en un nom différent (e.g. key column="workspaceid") afin de savoir sur quelle table survient le problème ...

    sylvain_2020

  7. #7
    Membre actif
    Profil pro
    Inscrit en
    Septembre 2005
    Messages
    504
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2005
    Messages : 504
    Points : 288
    Points
    288
    Par défaut
    merci pour ta reponse, j'ai donc changer le nom de toutes les key column des bag (an rajoutant 1,2,3...) mais l'erreur est toujours la meme.
    ce qui est bizarre c'est qu'en regardant le contenu de la base mySQL, effectivement pour les Sensor, il y en a un où la valeur de la colonne est null, donc a mon avis je vais ensuite avoir une erreur là plustard.

    MAis pour l'instant l'erreur ne peut porter que sur id...

  8. #8
    Membre actif
    Profil pro
    Inscrit en
    Septembre 2005
    Messages
    504
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2005
    Messages : 504
    Points : 288
    Points
    288
    Par défaut
    ok, donc je ne sais pas comment cela se fait, mais l'erreur est partie, c'est vrai que j'ai fait une petite manip, mais je ne vois pas, ce que cela change.
    en effet jusqu'a présent je créai mes tables à chaques exportations, avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    new SchemaExport(configuration).create(false, true);
    j'ai mis cette ligne en commentaire (vu que mes tables étaient dejà créer), j'ai lancé et je suis passé sur une autre errreur, bref...
    cela m'a semblé bizarre, donc j'ai dé-commenter ma ligne et je suis retombé sur ma nouvelle erreur.
    ce qui est bizarre c'est que maintenant meme en laissant new SchemaExport, l'erreur sur la valeur NULL n'apparait pas... si quelqu'un a dejà eu ce probleme... je veux bien une explication.

    voila si qq'1 peut m'expliquer. MErci d'avance de votre aide

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Hibernate Exception et Mysql
    Par doukou10 dans le forum Hibernate
    Réponses: 1
    Dernier message: 14/11/2008, 17h05
  2. Différence entre MySql et sql serveur
    Par nina_2006 dans le forum Décisions SGBD
    Réponses: 3
    Dernier message: 30/10/2006, 16h12
  3. Pb boolean entre MySQL/SQL Server
    Par [DreaMs] dans le forum Langage SQL
    Réponses: 1
    Dernier message: 21/07/2006, 16h58
  4. Pb boolean entre MySQL/SQL Server
    Par [DreaMs] dans le forum Bases de données
    Réponses: 1
    Dernier message: 19/07/2006, 10h03

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo