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

Développement SQL Server Discussion :

remplacement automatique d'apostrophe par \'


Sujet :

Développement SQL Server

  1. #1
    Membre averti Avatar de argonath
    Homme Profil pro
    Ingénieur d'Etudes
    Inscrit en
    Juillet 2009
    Messages
    248
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'Etudes
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2009
    Messages : 248
    Points : 381
    Points
    381
    Par défaut remplacement automatique d'apostrophe par \'
    bonjour,

    j'ai une fonction qui me complète automatiquement une table avec des informations d'une autre dont je met le code ci dessous.

    Mon problème est que parfois, j'ai des chaines de caractères avec des apostrophes (des adresses par exemple : 8 rue de l'orme )

    comment pourrais-je faire pour que le code en tienne compte ? merci

    comme le dit le titre, j'imagine pouvoir mettre un caractère d'échappement... mais difficile de voir comment aller le mettre au bon endroit dans cette procédure

    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
     
    CREATE PROCEDURE [dbo].[achievement] AS 
    DECLARE @colonne varchar(64), @CREATE varchar(max), @dataType varchar(32), @length varchar(32), @INSERT varchar(max), @TABLE varchar(32)
    SET @TABLE = 'OptinsCommerciaux' 
     
    DECLARE curseurVariables CURSOR FOR 
    SELECT COLUMN_NAME FROM INFORMATION_SCHEMA.COLUMNS 
    WHERE TABLE_NAME = @TABLE
    OPEN curseurVariables 
    FETCH curseurVariables INTO @colonne 
     
     
    WHILE @@FETCH_STATUS = 0 BEGIN
    PRINT @colonne
    IF @colonne = 'email' BEGIN FETCH curseurVariables INTO @colonne PRINT @colonne END
    SET @CREATE = 'CREATE TABLE TMP (EMAIL varchar(64), colonneCourante '
    SET @dataType = (SELECT data_type FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME = 'test' AND column_name = @colonne) 
    SET @length = (SELECT character_maximum_length FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME = 'test' AND column_name = @colonne) 
     
    IF (@dataType = 'varchar') 
    BEGIN SET @CREATE = @CREATE + @dataType + '(' + @length + '))' END 
    ELSE BEGIN SET @CREATE = @CREATE + @dataType + ')' END 
    PRINT ( @CREATE ) 
    EXEC ( @CREATE ) 
    SET @INSERT = 'INSERT INTO Tmp (email,colonneCourante) select ' + @TABLE + '.email, ' + @TABLE + '.[' + @colonne + '] from ' + @TABLE + ' INNER JOIN test on test.email = ' + @TABLE + '.email ' + 'where test.[' + @colonne + '] is null' 
    PRINT ( @INSERT ) 
    EXEC ( @INSERT ) 
    DECLARE @TraitementMail VARCHAR(50), @TraitementColonne VARCHAR(50), @SQL VARCHAR(max), @DEL VARCHAR(max) 
     
    WHILE EXISTS (SELECT TOP 1 Email FROM Tmp) 
    BEGIN 
    SET @TraitementMail = (SELECT TOP 1 Email FROM Tmp) 
    SET @TraitementColonne = (SELECT TOP 1 colonneCourante FROM Tmp)
    SET @SQL = 'UPDATE test SET test.[' + @colonne + '] = ''' + @TraitementColonne + ''' WHERE Email = ''' + @TraitementMail + ''';' 
    PRINT (@SQL)
    EXEC (@SQL) 
    SET @DEL = 'DELETE FROM Tmp WHERE Email = ''' + @TraitementMail + ''';' 
    PRINT (@DEL) 
    EXEC (@DEL) 
    END 
    DROP TABLE Tmp
    FETCH curseurVariables INTO @colonne
    END

  2. #2
    Modérateur

    Homme Profil pro
    Développeur java, access, sql server
    Inscrit en
    Octobre 2005
    Messages
    2 711
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur java, access, sql server
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 711
    Points : 4 797
    Points
    4 797
    Par défaut
    Il faut doubler les apostrophes
    et comme l'ordre INSERT est dans une variable, il faut quadrupler les apostrophes

    Si on a une colonne [Adresse] contenant "8 rue de l'orme"
    il faut composer
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SET @INSERT = 'INSERT INTO Tmp (MonChamp) SELECT ' + REPLACE(Adresse,'''','''''') + ' FROM LaTableAdresse'
    Labor improbus omnia vincit un travail acharné vient à bout de tout - Ambroise Paré (1510-1590)

    Consulter sans modération la FAQ ainsi que les bons ouvrages : http://jmdoudoux.developpez.com/cours/developpons/java/

  3. #3
    Membre averti Avatar de argonath
    Homme Profil pro
    Ingénieur d'Etudes
    Inscrit en
    Juillet 2009
    Messages
    248
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'Etudes
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2009
    Messages : 248
    Points : 381
    Points
    381
    Par défaut
    houlà oui c'est du brutal :p

    merci beaucoup

    edit : c'est dans l'update, pas dasn l'insert que le problème se pose en fait, mais je peux toujours utiliser replace je pense

Discussions similaires

  1. Remplacer automatiquement une page en html par une autre
    Par vigiepresse dans le forum Balisage (X)HTML et validation W3C
    Réponses: 9
    Dernier message: 23/10/2010, 15h44
  2. php remplace apostrophe par ’
    Par stefart dans le forum Langage
    Réponses: 9
    Dernier message: 30/11/2009, 17h09
  3. comment remplacer automatiquement le passage à la ligne classique par <br>
    Par tonelli dans le forum Balisage (X)HTML et validation W3C
    Réponses: 9
    Dernier message: 17/09/2007, 23h07
  4. [SQL] remplacement d'un espace ou d'une apostrophe par un tiret bas
    Par jophp dans le forum PHP & Base de données
    Réponses: 20
    Dernier message: 25/06/2006, 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