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

Grails Java Discussion :

SQL Insert Query+ Grails


Sujet :

Grails Java

  1. #1
    Nouveau membre du Club
    Inscrit en
    Février 2011
    Messages
    31
    Détails du profil
    Informations forums :
    Inscription : Février 2011
    Messages : 31
    Points : 25
    Points
    25
    Par défaut SQL Insert Query+ Grails
    Je suis débutante avec grails.

    J'ai un Domain Class appelé Item

    J'ai besoin d'inserer dans Item.

    Mon domain Class est la suivante:
    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
     
    class Item {
     
        static constraints = {
    		serialNumber(unique:true,blank:false)
    		dateCreated()
        }
     
    	static belongsTo = [product:Product]
     
    	String serialNumber
    	Date dateCreated
     
    	String toString(){
    		return "${serialNumber}"
    	  }
    }
    je veux inserer dans la table qui correspond à cette classe j'ai procédé comme suit:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    def dataSource
    Sql sql = new Sql(dataSource)
    sql.executeInsert("insert into Item (id , serialNumber , dateCreated , product) values( "+9+ ", '"+ 9 +"','" +new Date()+"',1)")
    Mais ça me génére l'exception suivante:
    Class:org.h2.jdbc.JdbcSQLExceptionMessage:Column "SERIALNUMBER" not found; SQL statement: insert into Item (id , serialNumber , dateCreated , product) values( 9, '9','Thu May 10 10:13:41 GMT+01:00 2012',1) [42122-164]
    je sais pas comment savoir exactement le schema de la table correspondant à chaque Domain class.

    Merci.

  2. #2
    Nouveau membre du Club
    Inscrit en
    Février 2011
    Messages
    31
    Détails du profil
    Informations forums :
    Inscription : Février 2011
    Messages : 31
    Points : 25
    Points
    25
    Par défaut
    j'ai ajouter ceci dans le domain Class Item:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    static mapping = {
    		id column: "item_id"
    		serialNumber: "s_number"
    		product column: 'product_id'
    		dateCreated column: 'dateC'
    }
    Et j'ai changé ma requete SQL:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sql.executeInsert("insert into Item i (i.item_id , i.s_number , i.dateC , i.product_id) values( "+9+ ", '"+ 9 +"','" +new Date()+"',"+ pr +")")
    avec pr: l'identifiant d'un élément produit passé dans un formulaire.

    mais ça n'a pas resolu le probléme et ça m'affiche cette exception:

    Message:Syntax error in SQL statement "INSERT INTO ITEM I[*] (I.ITEM_ID , I.S_NUMBER , I.DATEC , I.PRODUCT_ID) VALUES( 9, '9','Thu May 10 10:44:08 GMT+01:00 2012',1) "; expected "., (, DIRECT, SORTED, DEFAULT, VALUES, SET, (, SELECT, FROM"; SQL statement: insert into Item i (i.item_id , i.s_number , i.dateC , i.product_id) values( 9, '9','Thu May 10 10:44:08 GMT+01:00 2012',1) [42001-164]
    Une reponse SVP

  3. #3
    Membre averti
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2005
    Messages
    218
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2005
    Messages : 218
    Points : 311
    Points
    311
    Par défaut
    Oui, ben là va falloir reprendre à 0 et commencer par faire un tuto de grails et oublier la syntaxe Java classique. Si qqn te répond juste pour ton cas ca ne te fera pas avancer plus que ca. Grails utilise la couche hibernate et pour moi c'est un non sens de coder du SQL, sauf éventuellement pour lancer des scripts spécifiques à une base(vacuum, analyze pour postgres par exemple).
    Génère tes controlleurs à partir de la commande "generate-all Item" et tu auras un aperçu de comment faire pour insérer, modifier ou supprimer un enregsitrement.

Discussions similaires

  1. Syntaxe tableaux dans ordre SQL INSERT
    Par lio33 dans le forum SQL
    Réponses: 6
    Dernier message: 19/10/2005, 17h07
  2. Réponses: 2
    Dernier message: 30/09/2005, 15h41
  3. Multiplier les And dans Sql Insert Into
    Par samlepiratepaddy dans le forum Requêtes et SQL.
    Réponses: 17
    Dernier message: 23/09/2005, 21h55
  4. Réponses: 4
    Dernier message: 30/01/2005, 14h23
  5. erreur SQL ...INSERT INTO
    Par naidinp dans le forum ASP
    Réponses: 20
    Dernier message: 18/09/2003, 11h38

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