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

Bibliothèques et frameworks PHP Discussion :

[PEAR][MDB2] Insert et valeur NULL [Fait]


Sujet :

Bibliothèques et frameworks PHP

  1. #1
    Membre régulier
    Inscrit en
    Juin 2004
    Messages
    242
    Détails du profil
    Informations forums :
    Inscription : Juin 2004
    Messages : 242
    Points : 94
    Points
    94
    Par défaut [PEAR][MDB2] Insert et valeur NULL
    Bonjour,

    Je voudrais faire l'insertion d'une valeur NULL dans ma base de données mysql 5 avec la méthode autoexecute de PEAR

    le requête a passer est
    INSERT INTO fournisseur ( Lib_Fourn, Date_Jour) VALUES (?, ?)
    voila mon code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    $table = 'user'
    $field_value_ar = array('test',NULL);
    $mdb->autoExecute($table, $field_value_ar,MDB2_AUTOQUERY_INSERT,$where,array('blob', 'clob'));
    $field_value_ar2 = array('NULL','2003-01-01');
    $mdb->autoExecute($table, $field_value_ar2,MDB2_AUTOQUERY_INSERT,$where,array('blob', 'clob'));
    La structure de la table permet les valeurs nulls et a NULL par défaut.
    Dans le premier cas, dans le champ date j'ai une cellule vide et dans le second, dans le champs lib_fourn j'ai NULL mais pris en chaine de caractère et non en valeur NULL.

    Comment faire pour alimenter ma table avec de valeurs NULL?
    merci de votre réponse

  2. #2
    Rédacteur

    Homme Profil pro
    Geek entrepreneur
    Inscrit en
    Novembre 2004
    Messages
    1 224
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Geek entrepreneur

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 224
    Points : 2 373
    Points
    2 373
    Par défaut
    salut,

    ça fait des lustres que je n'y ai pas touché mais par défaut j'aurais tout simplement tenté de ne pas renseigner les valeurs pour les colonnes NULL.
    si je me réfère a la doc :

    http://pear.php.net/manual/en/packag...intro-auto.php :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    $fields_values = array(
        'id'      => 1,
        'name'    => 'Fabien',
        'country' => 'France'
    );
    $types = array('integer', 'text', 'text');
     
    $mdb2->loadModule('Extended');
    $affectedRows = $mdb2->extended->autoExecute($table_name, $fields_values,
                            MDB2_AUTOQUERY_INSERT, null, $types);
    pour mettre country a NULL par exemple, j'aurais fait ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    $fields_values = array(
        'id'      => 1,
        'name'    => 'Fabien'
    );
    $types = array('integer', 'text', 'text');
     
    $mdb2->loadModule('Extended');
    $affectedRows = $mdb2->extended->autoExecute($table_name, $fields_values,
                            MDB2_AUTOQUERY_INSERT, null, $types);

  3. #3
    Membre régulier
    Inscrit en
    Juin 2004
    Messages
    242
    Détails du profil
    Informations forums :
    Inscription : Juin 2004
    Messages : 242
    Points : 94
    Points
    94
    Par défaut
    Merci pour votre réponse en ligne. Par contre elle m'amène à une autre question...

    dans votre réponse, vous déclarer le le type de chacun des champs de votre table dans $type.

    En suivant votre tutoriel, j'ai déclarer $type = array('blob', 'clob')

    je n'ai pas bien compris cet histoire de large objet. Est ce que la déclaration faites ainsi est correcte oou faut 'il a chacune des requêtes passer le tableau des types de colonne?

    merci d'avance de l'attention que vous prêterez a cette nouvelle requête

  4. #4
    Rédacteur

    Homme Profil pro
    Geek entrepreneur
    Inscrit en
    Novembre 2004
    Messages
    1 224
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Geek entrepreneur

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 224
    Points : 2 373
    Points
    2 373
    Par défaut
    Les large object sont fait pour stocker de grande quantités de données, soit binaires (des images par exemple) dans des blob, soit des caractères dans des clob. Si c'est pour insérer un fournisseur et une date, je déconseille d'utiliser ce type de champ.
    Pour ce qui est de la syntaxe ci dessous, il me semble effectivement que vous repassez les types de champ à chaque appel à autoexecute.

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

Discussions similaires

  1. [PDO] insert into ==> Valeurs NULL
    Par armand6464 dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 17/05/2015, 16h30
  2. [VB.NET] insertion la valeur null apartir d'un maskedtextbox
    Par messi1987 dans le forum Débuter
    Réponses: 2
    Dernier message: 02/03/2014, 11h09
  3. Réponses: 3
    Dernier message: 22/01/2013, 16h23
  4. [Elementum] Insertion de valeurs nulles dans une colonne numérique d'un table
    Par cquilgars dans le forum Autres outils décisionnels
    Réponses: 2
    Dernier message: 17/07/2012, 11h50
  5. Valeur null lors de la lecture apres un insert
    Par omlip dans le forum Hibernate
    Réponses: 1
    Dernier message: 07/07/2006, 13h56

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