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

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  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

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