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

Doctrine2 PHP Discussion :

Problème de création de table


Sujet :

Doctrine2 PHP

  1. #1
    Membre averti
    Femme Profil pro
    Inscrit en
    Mars 2013
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations forums :
    Inscription : Mars 2013
    Messages : 16
    Par défaut Problème de création de table
    Salut,

    Je suis débutante avec le framework symfony. Je suis entrain de suivre le tutoriel "créer sa première application en PHP avec Symfony 2" qui est disponible sur le site.J'ai crée la base mais j'ai pas pu créer les tables j'ai tapé dans le console la commande :php app/console doctrine:schema:create.
    mais le message affiché est:

    [Doctrine\Common\Annotations\AnnotationException]
    [Type Error] Attribute "length" of @ORM\Column declared on property MyApp\F
    ilmothequeBundle\Entity\Acteur::$nom expects a(n) integer, but got string.

    doctrine:schema:create [--dump-sql] [--em[="..."]]

  2. #2
    Membre extrêmement actif
    Avatar de dukoid
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2012
    Messages
    2 100
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2012
    Messages : 2 100
    Par défaut
    comme ça, apparamment tu utilise un attribut LENGTH pour un INTEGER alors que ça s'utilise pour un STRING

    fais attention length est un mot reservé en SQL, à ne pas utiliser.

    c'est mieux que tu nous affiche le code pour qu'on puisse voir

  3. #3
    Membre averti
    Femme Profil pro
    Inscrit en
    Mars 2013
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations forums :
    Inscription : Mars 2013
    Messages : 16
    Par défaut
    bonjour,
    c'est mon code
    <?php
    namespace Myapp\generateurBundle\Entity;
    use Doctrine\ORM\Mapping as ORM;
    use Symfony\Component\Validator\Constraints as Assert;
    /**
    * @ORM\Entity
    */
    class Utilisateur
    {
    /**
    * @ORM\GeneratedValue
    * @ORM\Id
    * @ORM\Column(type="integer")
    */
    private $id;
    /**
    * @ORM\Column(type="string",length="255")
    * @Assert\NotBlank()
    * @Assert\MinLength(3)
    */
    private $nom;
    /**
    * @ORM\Column(type="string")
    * @Assert\NotBlank()
    * @Assert\MinLength(3)
    */
    private $prenom;
    /**
    * @ORM\Column(type="date")
    * @Assert\NotBlank()
    */

    private $dateNaissance;
    /**
    * @ORM\Column(type="date")
    * @Assert\NotBlank()
    */

    private $pwd;
    /**
    * @ORM\Column(type="string",length="255")
    * @Assert\NotBlank()
    * @Assert\MinLength(3)
    */
    }
    ?>

  4. #4
    Membre éclairé Avatar de FadeToBlack
    Homme Profil pro
    ...
    Inscrit en
    Août 2010
    Messages
    321
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : ...
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Août 2010
    Messages : 321
    Par défaut
    Salut minouchaimen,

    dans ton attribut length du mets des doubles quotes. Comme il s'agit de nombre il ne faut pas en mettre .

    exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    /**
    * @ORM\Column(type="string",length=255)
    * @Assert\NotBlank()
    * @Assert\MinLength(3)
    */
    private $nom;
    au lieu de
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    /**
    * @ORM\Column(type="string",length="255")
    * @Assert\NotBlank()
    * @Assert\MinLength(3)
    */
    private $nom;

  5. #5
    Membre averti
    Femme Profil pro
    Inscrit en
    Mars 2013
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations forums :
    Inscription : Mars 2013
    Messages : 16
    Par défaut
    salut,
    j'ai une autre problème , si je tape http://localhost/tutos/videotheque/w...dev.php/myapp/ j'obtien comme message

    FatalErrorException: Error: Call to undefined method Myapp\generateurBundle\Entity\Utilisateur::setnom() in C:\wamp\www\tutos\videotheque\src\Myapp\generateurBundle\Controller\DefaultController.php line 15

    voici ma classe utilisateur:



    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
    22
    23
    24
    25
    26
    27
    28
    29
    <?php
    namespace Myapp\generateurBundle\Entity;
    use Doctrine\ORM\Mapping as ORM;
    use Symfony\Component\Validator\Constraints as Assert;
    /**
    * @ORM\Entity
    */
    class Utilisateur
    {
    /**
    * @ORM\GeneratedValue
    * @ORM\Id
    * @ORM\Column(type="string")
    */
    private $id;
    /**
    * @ORM\Column(type="string")
    * @Assert\NotBlank()
    * @Assert\MinLength(3)
    */
    private $nom;
    /**
    * @ORM\Column(type="string")
    * @Assert\NotBlank()
    * @Assert\MinLength(3)
    */
     
    }
    ?>

    et c'est mon code DefaultController.php

    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
    22
    23
    24
    25
    <?php
     
    namespace Myapp\generateurBundle\Controller;
     
    use Symfony\Component\DependencyInjection\ContainerAware,
    Symfony\Component\HttpFoundation\RedirectResponse;
    use Myapp\generateurBundle\Entity\Utilisateur;
    class DefaultController extends ContainerAware
     
    {
        public function indexAction()
        {
            $em = $this->container->get('doctrine')->getEntityManager();
    		$Utilisateur1= new Utilisateur ();
    		$Utilisateur1->setnom('Imen');
     
    		$em->persist($Utilisateur1);
    		$em->flush();
    		$message = 'utilisateur créés avec succès';
    		return $this->container->get('templating')->renderResponse('MyAppGenerateurBundle:Default:index.html.twig',
            array('message' => $message)
    		);
        }
    }
    ?>

  6. #6
    Membre éclairé Avatar de FadeToBlack
    Homme Profil pro
    ...
    Inscrit en
    Août 2010
    Messages
    321
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : ...
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Août 2010
    Messages : 321
    Par défaut
    A priori, lors que tu as créé ton entité, tu n'as pas généré les getters et les setters, pour obtenir :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    public function setnom(){}
    et

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    public function getnom()
    etc....

    il faut qut tu fasse en console

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    php app/console doctrine:generate:entities  Myapp\generateurBundle\utilisateur
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    php app/console doctrine:generate:entities  utilisateur
    chez moi çà marche

    ou encore

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    php app/console doctrine:generate:entities  Myapp\generateurBundle
    pour générer tous les getters et setters de toutes tes entités

  7. #7
    Membre averti
    Femme Profil pro
    Inscrit en
    Mars 2013
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations forums :
    Inscription : Mars 2013
    Messages : 16
    Par défaut
    tjs la même problème

  8. #8
    Membre éclairé Avatar de FadeToBlack
    Homme Profil pro
    ...
    Inscrit en
    Août 2010
    Messages
    321
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : ...
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Août 2010
    Messages : 321
    Par défaut
    est-ce que tu as tes getters et tes setters dans ton entité utilisateur ?

    Mets le code après le php app/console doctrine:generate:entities etc.....

  9. #9
    Invité
    Invité(e)
    Par défaut


    Y aurait pas une histoire de casse ? Genre "setNom()" au lieu de "setnom()" ?

  10. #10
    Membre averti
    Femme Profil pro
    Inscrit en
    Mars 2013
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations forums :
    Inscription : Mars 2013
    Messages : 16
    Par défaut
    c'est ce que j'ai écrit dans le console et ce que j'ai obtient:

    c:\wamp\www\tutos\videotheque>php app/console doctrine:generate:entities Myapp\generateurBundle
    Generating entities for namespace "Myapp\generateurBundle"
    > backing up Utilisateur.php to Utilisateur.php~
    > generating Myapp\generateurBundle\Entity\Utilisateur

  11. #11
    Membre averti
    Femme Profil pro
    Inscrit en
    Mars 2013
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations forums :
    Inscription : Mars 2013
    Messages : 16
    Par défaut
    Citation Envoyé par David Guillot Voir le message


    Y aurait pas une histoire de casse ? Genre "setNom()" au lieu de "setnom()" ?
    salut bien sure j'ai essayé avec setNom je suis avec cette probléme depuis 4h au min en tt cas merci pour l'aide

  12. #12
    Membre éclairé Avatar de FadeToBlack
    Homme Profil pro
    ...
    Inscrit en
    Août 2010
    Messages
    321
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : ...
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Août 2010
    Messages : 321
    Par défaut
    oh punaise quel truf, je me fais toujours avoir avec cette histoire de casse.

    Je me demande quel est le c..... qui a inventé ces trucs

    effectivement dans les setters tu as :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
     
    class Utilisateur{
       public function setNom($nom){
            $this->nom = $nom;
     
            return $this;
        }
    et
         public function getNom(){
    .....
         }
    }
    donc du coup dans ton controlleur tu mets
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
     $em = $this->container->get('doctrine')->getEntityManager();
    		$Utilisateur1= new Utilisateur ();
    		$Utilisateur1->setNom('Imen');

  13. #13
    Invité
    Invité(e)
    Par défaut
    @FadeToBlack Apparemment du fait que @minouchaimen est sous Windows la casse ne s'applique pas... Cependant il faut y faire attention quand on veut développer une application pour la passer en production sur un serveur Linux . Ce que je me demande surtout, c'est comment des gens ont pu coder un OS dans lequel "e" === "E"....

    @minouchaimen, montre-nous le code de ton entité Utilisateur maintenant que tu l'as mise à jour via Doctrine

  14. #14
    Membre éclairé Avatar de FadeToBlack
    Homme Profil pro
    ...
    Inscrit en
    Août 2010
    Messages
    321
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : ...
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Août 2010
    Messages : 321
    Par défaut
    ha oui c'est vrai qu'il y a ce pd de Windows.......

    Depuis le temps que je fricotte avec Nunux, je l'avais oublié


    Minouchaimen : David a raison, mets nous le code de ta classe utilisateur

  15. #15
    Membre averti
    Femme Profil pro
    Inscrit en
    Mars 2013
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations forums :
    Inscription : Mars 2013
    Messages : 16
    Par défaut
    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
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    <?php
    namespace Myapp\generateurBundle\Entity;
    use Doctrine\ORM\Mapping as ORM;
    use Symfony\Component\Validator\Constraints as Assert;
    /**
    * @ORM\Entity
    */
    class Utilisateur
    {
    /**
    * @ORM\GeneratedValue
    * @ORM\Id
    * @ORM\Column(type="string")
    */
    private $id;
    /**
    * @ORM\Column(type="string")
    * @Assert\NotBlank()
    * @Assert\MinLength(3)
    */
    private $nom;
    /**
    * @ORM\Column(type="string")
    * @Assert\NotBlank()
    * @Assert\MinLength(3)
    */
     
     
     
    public function setNom($nom){
      $this->nom= $nom;
    }
     
    public function getNom(){
    return $this->nom;
    }
    }
    ?>

  16. #16
    Membre éclairé Avatar de FadeToBlack
    Homme Profil pro
    ...
    Inscrit en
    Août 2010
    Messages
    321
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : ...
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Août 2010
    Messages : 321
    Par défaut
    ça à l'air bon...

    Tu as toujours la même erreur ???

    Et ton routing est correct ?

  17. #17
    Invité
    Invité(e)
    Par défaut
    Je ferais un petit app/console cache:clear pour m'assurer que tout est bien remis en ordre...

  18. #18
    Membre averti
    Femme Profil pro
    Inscrit en
    Mars 2013
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations forums :
    Inscription : Mars 2013
    Messages : 16
    Par défaut
    merciiiiiiiiiiii enfin ça marche

Discussions similaires

  1. Réponses: 3
    Dernier message: 06/01/2008, 21h22
  2. problème de création de table
    Par /*Mr.D*/ dans le forum Outils
    Réponses: 4
    Dernier message: 02/12/2007, 22h36
  3. Oracle 9.2 problème de création de table
    Par Dadou74 dans le forum Administration
    Réponses: 3
    Dernier message: 29/03/2007, 14h07
  4. [SQL-Server] Problème query création de tables sous PHP
    Par DjSoulz dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 27/03/2007, 22h18
  5. Problème de création de table sous MySql
    Par ducamba dans le forum Requêtes
    Réponses: 2
    Dernier message: 21/06/2003, 09h59

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