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

SGBD Perl Discussion :

comment inserer un text dans Mysql


Sujet :

SGBD Perl

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Avril 2007
    Messages
    28
    Détails du profil
    Informations forums :
    Inscription : Avril 2007
    Messages : 28
    Par défaut comment inserer un text dans Mysql
    bonjour,
    j ai une chaine de caractere qui contient des (,>,<,"",'',.....) et je voudrais l'inserer dans une base Mysql dans une table qui contient deux champs (id INT,valeur TEXT) mais il ya un probleme dans les caracteres (",'...) si j avais compris .
    voila le code:
    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
     
    # MYSQL CONFIG VARIABLES 
    $host = "localhost";
     $database = "lapresse"; 
    $tablename = "article"; 
     
     $user = "root@localhost";
     $pw = ""; 
     #PERL MYSQL CONNECT()
     $connect = Mysql->connect($host, $database, $user, $pw); 
     #SELECT DB 
    $connect->selectdb($database);
     $myquery = "INSERT INTO $tablename (id, valeur) VALUES (?,?)"; 
     
    si vous avez des solutions s'il vous plait aidez moi!!!! c'est urgent
    et merci pour vous en avance
    cordialement..............
     
     
     
     
    ##############################################
    my $separateur = "</a>";
     
    my @tab = split($separateur, $page);
     
    foreach $var (@tab)
    {
    if (!((substr($var,0,4) eq "HTTP") or (substr($var,0,3) le "<") or (substr($var,0,1) eq "<")))
    {  
     # EXECUTE THE QUERY FUNCTION
     $execute = $connect->query($myquery);
    $myquery="INSERT  INTO article(id,valeur) VALUE (DEFAULT,$var)";
     # AFFECTED ROWS 
    $affectedrows = $execute->affectedrows($myquery);
     # ID OF LAST INSERT 
    $lastid = $execute->insertid($myquery);
     
       print "\n*****************************************************************\n";
    }
    }

  2. #2
    Responsable Perl et Outils

    Avatar de djibril
    Homme Profil pro
    Inscrit en
    Avril 2004
    Messages
    19 822
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 19 822
    Par défaut
    pensez à mettre vos codes sous balise la prochaine fois

  3. #3
    Membre averti
    Inscrit en
    Avril 2007
    Messages
    28
    Détails du profil
    Informations forums :
    Inscription : Avril 2007
    Messages : 28
    Par défaut desoler djibril
    en fait c est que je voudrais c est comment inserer une chaine de caractere qui contient des virgules et des apostrofs... dans une base Mysql?
    et merci d'avance

  4. #4
    Membre Expert
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2003
    Messages
    1 605
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2003
    Messages : 1 605
    Par défaut
    Il te suffit de doubler les caractères concernés en mettant le caractère \ devant chacun d'eux

    Ainsi,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    insert into table values (nom = 'd'artagnan')
    devient
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    insert into table values (nom = 'd\'artagnan')

  5. #5
    Expert confirmé
    Avatar de Jedai
    Homme Profil pro
    Enseignant
    Inscrit en
    Avril 2003
    Messages
    6 245
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Avril 2003
    Messages : 6 245
    Par défaut
    Citation Envoyé par Arioch
    Il te suffit de doubler les caractères concernés en mettant le caractère \ devant chacun d'eux

    Ainsi,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    insert into table values (nom = 'd'artagnan')
    devient
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    insert into table values (nom = 'd\'artagnan')
    Encore mieux (et plus sûr) :
    tu prepare() la requete :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    insert into table values (nom = ?)
    et ensuite tu :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $query->execute("d'artagnan");
    Et tout sera arrangé automatiquement pour toi par DBI.

    --
    Jedaï

Discussions similaires

  1. Comment inserer une image dans le texte d'une réponse
    Par dde63 dans le forum Mode d'emploi & aide aux nouveaux
    Réponses: 3
    Dernier message: 28/03/2014, 17h36
  2. Réponses: 4
    Dernier message: 17/11/2008, 15h28
  3. Réponses: 0
    Dernier message: 15/03/2008, 09h59
  4. comment ecrire du texte dans une window application
    Par gaut dans le forum Autres éditeurs
    Réponses: 2
    Dernier message: 16/07/2003, 10h23
  5. Comment centrer un Texte dans un rectangle ...
    Par Djedjeridoo dans le forum Composants VCL
    Réponses: 3
    Dernier message: 16/06/2003, 21h56

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