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

Firebird Discussion :

Firebird - Comment copier des champs blob en procedure stockée


Sujet :

Firebird

  1. #1
    Membre éclairé

    Homme Profil pro
    Fondateur de ZetaPush - realtime BaaS
    Inscrit en
    Mars 2002
    Messages
    146
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Fondateur de ZetaPush - realtime BaaS
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2002
    Messages : 146
    Points : 687
    Points
    687
    Par défaut Firebird - Comment copier des champs blob en procedure stockée
    Bonjour,

    Dans ma base de données FB, j'ai une procedure stockée qui copie les champs d'une table vers une autres.
    Dans ma table1, j'ai un champ de type Blob (Texte) qui doit être copié dans un champ de ma table2 de type Blob (Texte).

    Tout fonctionne à merveille sauf quand dans mon champ blob à copier, il y a des apostrophe ' . Dès lors, l'apostrophe est reconnue comme séparateur dans ma requête SQL et ma requête plante.

    Quelqu'un sait-il comment réussir à échapper le texte du Blob?

    Merci d'avance,
    Mikaël Morvan

  2. #2
    Membre expert

    Homme Profil pro
    Consultant spécialité Firebird
    Inscrit en
    Mai 2002
    Messages
    2 342
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France

    Informations professionnelles :
    Activité : Consultant spécialité Firebird
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 342
    Points : 3 715
    Points
    3 715
    Par défaut
    si on voyait ton code se serait plus simple pour éventuellement aider

  3. #3
    Membre éclairé

    Homme Profil pro
    Fondateur de ZetaPush - realtime BaaS
    Inscrit en
    Mars 2002
    Messages
    146
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Fondateur de ZetaPush - realtime BaaS
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2002
    Messages : 146
    Points : 687
    Points
    687
    Par défaut
    Effectivement

    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
     
    create or alter procedure "InsertArticleTopic" (
        "IDTopic" integer,
        "IDArticle" integer)
    as
    declare variable SQL varchar(1000);
    declare variable "IDArticleSection" varchar(50);
    declare variable "Comment" blob sub_type 0 segment size 80;
    begin
      for select "IDArticleTopicSection" , "Comment" from "articleTopicSection"
        where "IDArticleTopic" = :"IDTopic"
      into :"IDArticleSection", :"Comment"
      do
      begin
     
        Sql = 'Insert into ArticleSection (IDArticle, IDARTICLESECTION, comment) values (' ||:"IDArticle" ||',''' || :"IDArticleSection" ||''',''' ||:"Comment" || ''')';
     
        Execute Statement :Sql;
      end
     
    end
    avec dans le code le champ Comment qui est un Blob.

  4. #4
    Membre confirmé Avatar de TryExceptEnd
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2006
    Messages
    501
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2006
    Messages : 501
    Points : 576
    Points
    576
    Par défaut
    Et si au-lieu de ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Sql = 'Insert into ArticleSection (IDArticle, IDARTICLESECTION, comment) values (' ||:"IDArticle" ||',''' || :"IDArticleSection" ||''',''' ||:"Comment" || ''')';
     
        Execute Statement :Sql;
    tu écrit directement ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Insert into ArticleSection (IDArticle, IDARTICLESECTION, comment) values (:"IDArticle", :"IDArticleSection", :"Comment");

  5. #5
    Membre éclairé

    Homme Profil pro
    Fondateur de ZetaPush - realtime BaaS
    Inscrit en
    Mars 2002
    Messages
    146
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Fondateur de ZetaPush - realtime BaaS
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2002
    Messages : 146
    Points : 687
    Points
    687
    Par défaut
    Super, ça marche

    Je ne sais pas pourquoi j'ai été compliquer les choses avec mon écriture alambiquée

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

Discussions similaires

  1. [Firebird] Comment gérer des groupes d'utilisateur
    Par stundman dans le forum Administration
    Réponses: 3
    Dernier message: 16/11/2005, 13h30
  2. comment lire le champs BLOB
    Par simcity1969 dans le forum InterBase
    Réponses: 5
    Dernier message: 05/10/2005, 13h44
  3. cherche comment copier le champ vers une autre champ
    Par khier dans le forum Décisions SGBD
    Réponses: 2
    Dernier message: 01/07/2005, 12h20
  4. [ADO.Net][VB.NET] Comment copier des données entre deux BDD différentes ?
    Par maddog2032 dans le forum Accès aux données
    Réponses: 6
    Dernier message: 06/06/2005, 11h01
  5. [langage] Comment rajouter des champs dans une liste
    Par toto_titi dans le forum Langage
    Réponses: 4
    Dernier message: 28/08/2003, 14h09

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