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

Zend_Db PHP Discussion :

Enregistrement en DB


Sujet :

Zend_Db PHP

  1. #1
    Membre averti
    Homme Profil pro
    Etudiant
    Inscrit en
    Juillet 2008
    Messages
    37
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Etudiant

    Informations forums :
    Inscription : Juillet 2008
    Messages : 37
    Par défaut Enregistrement en DB
    Bonjour,

    j'ai un gros problème.

    J'utilise ZF depuis un bon petit moment, mais j'ai toujours utilisé le PDO Mysql. Or, pour un projet scolaire, je suis "obligé" d'utiliser SQL_SERVER.

    j'ai un crash dans ma methode "save()" qui est dans une classe "table" qui se trouve entre mes model & Zend_Db_Table_Abstract ( monModel extends table extends Zend_Db_Table_Abstract )

    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
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
     
    /**
      	 * Update / Insert into db
      	 *
      	 * @param array $data, if $data is null, will insert 
      	 * @return number the key value (id) of the saved object or false if error 
      	 */
      	public function save($data = null)
      	{
                if ($data === null)
                {
                    $data = $this->toArray();
                }
     
                $db = $this->getAdapter() ;
                $data = $this->_cleanData($data);
                reset($this->_primary) ;
                $primary = is_array($this->_primary) ? current($this->_primary) : $this->_primary ;
     
                $id = 0 ;
     
                if (array_key_exists($primary, $data) && $data[$primary])
                {
                    if(is_array($this->_primary) && count($this->_primary) > 1)
                            $id = array_intersect_key($data, array_flip($this->_primary)) ;
                    else
                            $id = $data[$primary] ;
     
                    $db = $this->getAdapter();
                    $where = array() ;
                    foreach($this->_primary as $key)
                    {
                        if(array_key_exists($key, $data) && $data[$key])
                        {
                            array_push($where, $db->quoteInto($key . ' = ?', $data[$key])) ;
                            unset($data[$key]);
                        }
                    }
     
                    $this->update($data, $where);
                }
                else
                {
                        if (array_key_exists($primary, $data))
                                unset($data[$primary]);
     
                        $id = $this->insert($data);
                }
     
                return $id;
      	}

    Cette fonction marche très bien sous MySql mais je ne peux rien enregistré sous SQL_SERVER

    si quelqu'un peu m'aider .

    merci d'avance !

  2. #2
    Membre Expert
    Avatar de Nesmontou
    Homme Profil pro
    Architecte logiciel
    Inscrit en
    Septembre 2004
    Messages
    1 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Architecte logiciel
    Secteur : Finance

    Informations forums :
    Inscription : Septembre 2004
    Messages : 1 612
    Par défaut
    Bonjour,

    Tu pourrais préciser ce qui se passe ?
    • Message d'erreur
    • Comportement différent de celui attendu
    • Rien ne se passe
    • ...

  3. #3
    Membre averti
    Homme Profil pro
    Etudiant
    Inscrit en
    Juillet 2008
    Messages
    37
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Etudiant

    Informations forums :
    Inscription : Juillet 2008
    Messages : 37
    Par défaut
    Désolé de t'avoir dérangé, l'erreur était ailleur ( problème de clé primaire dans la base ... )


    Merci quand meme !

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

Discussions similaires

  1. Perte d'enregistrements
    Par AnnSo dans le forum Paradox
    Réponses: 15
    Dernier message: 06/08/2006, 23h39
  2. [VB6] [Crystal] Selection enregistrement
    Par littlecow dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 11/01/2005, 13h08
  3. Enregistrer un RichEdit dans un .Txt
    Par Clément[Delphi] dans le forum Composants VCL
    Réponses: 2
    Dernier message: 06/08/2002, 11h52
  4. [BDD] Enregistrer le résultat d'une requête
    Par Mowgly dans le forum C++Builder
    Réponses: 5
    Dernier message: 19/06/2002, 15h26
  5. enregistrer dans un fichier avec une appli mdi
    Par ferrari dans le forum C++Builder
    Réponses: 4
    Dernier message: 05/05/2002, 15h17

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