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

MS SQL Server Discussion :

Comparer données colonnes de type Text


Sujet :

MS SQL Server

  1. #1
    Membre régulier
    Inscrit en
    Février 2008
    Messages
    276
    Détails du profil
    Informations forums :
    Inscription : Février 2008
    Messages : 276
    Points : 83
    Points
    83
    Par défaut Comparer données colonnes de type Text
    Bonjour tout le monde, J'ai crée une requête pour comparer les données de 2 colonne ayant le même type Text (Il s'agit en fait de la même structure de la base et juste les données sont modifiées).
    La requête que j'ai utilisée est
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    select t1.SPADM_SP_CODE_FK_PK, t1.SPADM_LIBELLE, t2.SPADM_SP_CODE_FK_PK,t2.SPADM_LIBELLE
    from THERIAQUE_DEST.theriaque.SPADM_SPECIALITE_MODEADM  t1
    inner join THERIAQUE_MAJ.theriaque.SPADM_SPECIALITE_MODEADM  t2 on t1.SPADM_SP_CODE_FK_PK = t2.SPADM_SP_CODE_FK_PK
    where cast(t1.SPADM_LIBELLE as varchar(max)) <> cast(t2.SPADM_LIBELLE as varchar(max))
    Normalement je dois avoir une différence car pour le même enregistrement la colonne "Libelle" de la 1ère base contient (350 mg/m²) et la seconde colonne contient (350 mg/m2).
    Est ce que quelqu'un pourrait m'éclaircir cette situation et m'aide à résoudre ce problème.
    Merci d'avance pour votre collaboration

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 865
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 865
    Points : 53 021
    Points
    53 021
    Billets dans le blog
    6
    Par défaut
    Normal les types LOB comme Text, Ntext et IMAGE ne sont pas relationnel. Donc certaines opérations sont impossibles.

    évitez de stocker des données que vous voulez manipuler sur le plan relationnel dans de telles colonnes.

    A +

  3. #3
    Membre régulier
    Inscrit en
    Février 2008
    Messages
    276
    Détails du profil
    Informations forums :
    Inscription : Février 2008
    Messages : 276
    Points : 83
    Points
    83
    Par défaut
    Merci pour votre réponse.
    Mais je n'ai pas le choix car il s'agit d'une base de données client et je dois détecter les mises à jour effectuées entre 2 bases.
    De plus, la même requête m'affiche d'autres différences entre plusieurs enregistrements mais pas cet enregistrement qui contient malgré tout une différence.

  4. #4
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 865
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 865
    Points : 53 021
    Points
    53 021
    Billets dans le blog
    6
    Par défaut
    Cela dépend à quel offset de la ligne se situe la différence.

    A +

  5. #5
    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 792
    Points
    4 792
    Par défaut
    Comme on ne peut pas utiliser CHECKSUM sur des champs Text,
    une possibilité est de créer une fonction utilisateur qui compare ces deux champs.

    Du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    CREATE FUNCTION [dbo].[CompText] (@Text1 Text, @Text2 Text)  
    RETURNS varchar(2) AS  
    BEGIN 
     
    DECLARE @R varchar(2)
     
    	SET @R = 'OK'
    	IF SUBSTRING(@Text1,1,8000) <> SUBSTRING(@Text2,1,8000) SET @R='KO'
     
     
    RETURN (@R)
     
    END
    Cette fonction est à utiliser dans la requête et retourne 'OK' si les chaînes sont identiques ou 'KO' s'il existe une différence.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT  dbo.CompText(t1.SPADM_LIBELLE, t2.SPADM_LIBELLE) AS test FROM ...
    Il faut naturellement étendre cette fonction pour les textes dépassants 8000 caractères (faire un boucle par exemple)

  6. #6
    Membre régulier
    Inscrit en
    Février 2008
    Messages
    276
    Détails du profil
    Informations forums :
    Inscription : Février 2008
    Messages : 276
    Points : 83
    Points
    83
    Par défaut
    Merci pour ta participation, mais cette fonction compare juste la longueur du texte mais moi je veux comparer les données elles même.

  7. #7
    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 792
    Points
    4 792
    Par défaut
    Pas du tout.
    La fonction compare les deux textes et signale s'il existe une différence.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    IF SUBSTRING(@Text1,1,8000) <> SUBSTRING(@Text2,1,8000) ...

  8. #8
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 865
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 865
    Points : 53 021
    Points
    53 021
    Billets dans le blog
    6
    Par défaut
    Non, elle compare le contenu des 8000 premiers caractères....

    A +

  9. #9
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Citation Envoyé par mercure07 Voir le message
    Merci pour ta participation, mais cette fonction compare juste la longueur du texte mais moi je veux comparer les données elles même.
    A mon sens, cette fonction compare les 8000 premiers caractères de deux variables de type text... pas leur longueur, mais bien leur valeur...

    ce que te disais Népomucène, c'est que si tu veux comparer au delà de 8000 caractères, il faudra faire une boucle, pour comparer 8000 par 8000 sur toute la longueur voulue...

  10. #10
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Points : 12 371
    Points
    12 371
    Par défaut
    Bonjour,

    Non, la fonction que vous a donné Népomucène compare bien les données.

    Si vous êtes sous SQL Server 2005 ou plus, vous pouvez transtyper ces deux colonnes au type varchar(max) ...

    @++

  11. #11
    Membre régulier
    Inscrit en
    Février 2008
    Messages
    276
    Détails du profil
    Informations forums :
    Inscription : Février 2008
    Messages : 276
    Points : 83
    Points
    83
    Par défaut
    Merci tout le monde pour vos réponses.
    En fait, j'ai déjà fait dans ma requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT t1.SPADM_SP_CODE_FK_PK, t1.SPADM_LIBELLE, t2.SPADM_SP_CODE_FK_PK,t2.SPADM_LIBELLE
    FROM THERIAQUE_DEST.theriaque.SPADM_SPECIALITE_MODEADM  t1
    INNER JOIN THERIAQUE_MAJ.theriaque.SPADM_SPECIALITE_MODEADM  t2 ON t1.SPADM_SP_CODE_FK_PK = t2.SPADM_SP_CODE_FK_PK
    WHERE cast(t1.SPADM_LIBELLE AS varchar(max)) <> cast(t2.SPADM_LIBELLE AS varchar(max))
    Ou vous voulez dire que je fasse le cast dans la
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    IF SUBSTRING(@Text1,1,8000) <> SUBSTRING(@Text2,1,8000)
    Si oui, alors comment faire.
    Merci encore pour votre apport

  12. #12
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Arff,

    non effectivement, tel que vous le faites dans votre premier post, c'est correct

    Vous avez en fait je pense un problème de collation.

    est-ce que ceci vous donne le resultat que vous attendez ?

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT t1.SPADM_SP_CODE_FK_PK, t1.SPADM_LIBELLE, t2.SPADM_SP_CODE_FK_PK,t2.SPADM_LIBELLE
    FROM THERIAQUE_DEST.theriaque.SPADM_SPECIALITE_MODEADM  t1
    INNER JOIN THERIAQUE_MAJ.theriaque.SPADM_SPECIALITE_MODEADM  t2 ON t1.SPADM_SP_CODE_FK_PK = t2.SPADM_SP_CODE_FK_PK
    WHERE cast(t1.SPADM_LIBELLE AS varchar(max)) <> cast(t2.SPADM_LIBELLE AS varchar(max)) COLLATE FRENCH_CS_AS

  13. #13
    Membre régulier
    Inscrit en
    Février 2008
    Messages
    276
    Détails du profil
    Informations forums :
    Inscription : Février 2008
    Messages : 276
    Points : 83
    Points
    83
    Par défaut
    Merci pour tous.
    C'est résolu avec le COLLATE.

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

Discussions similaires

  1. colonne de type TEXT et pourtant error, data too long
    Par boss_gama dans le forum Installation
    Réponses: 5
    Dernier message: 17/04/2007, 14h17
  2. Réponses: 3
    Dernier message: 22/10/2006, 23h15
  3. indexer les colonnes de type TEXT
    Par Bourak dans le forum Outils
    Réponses: 3
    Dernier message: 09/05/2006, 16h02
  4. Espace utilisé par une colonne de type TEXT
    Par efficks dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 07/02/2006, 16h34
  5. Réponses: 5
    Dernier message: 19/04/2005, 09h46

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