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 :

erreur de collation pour "UNION operation"


Sujet :

Développement SQL Server

  1. #1
    Membre du Club
    Étudiant
    Inscrit en
    Mars 2007
    Messages
    101
    Détails du profil
    Informations personnelles :
    Âge : 41

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2007
    Messages : 101
    Points : 64
    Points
    64
    Par défaut erreur de collation pour "UNION operation"
    Bonjour,

    J'ai développer un script T-SQL qui permet de m'afficher un ensemble de données, auparavant mon script marchait de façon impécable car il fait appel a deux instances sur deux serveurs sql 2000, j'ai réçament fait une migration sur un serveur sql 2005, et depuis le problème se multiplient.

    je dsipose d'un script du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    select champs1, champs2..
    into temptable
    from table1
    union 
    select champs1, champs2..
    from table2
    et je reçoit le message d'erreur suivant

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Msg*468, Niveau*16, État*9, Ligne*31
    Cannot resolve the collation conflict between "SQL_Latin1_General_CP1_CI_AS" and "French_CI_AI" in the UNION operation.
    mais lorsque je fait :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    select champs1, champs2..
    from table1
    Ou encore :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    select champs1, champs2..
    from table2
    La requete fourni le bon résultat!!

    Prière de m'aider à résoudre ce problème critique

    Merci d'avance pour votre aide

  2. #2
    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 : 42
    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,

    Je ne sais pas comment on retrouve la collation d'une colonne sous SQL Server 2000, mais ce qui est sûr c'est que les collations des colonnes des deux ensembles que vous tentez d'unir sont différentes.
    Si vous avez créé les tables sur les deux instances sans spécifier de collation, alors la collation de la base de données a été choisie.

    Vous pouvez changer la collation soit au niveau colonne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ALTER TABLE maTable
    ALTER COLUMN maColonne COLLATE maCollation
    soit au niveau base de données :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ALTER DATABASE maBD
    COLLATE maCollation
    ou encore dans votre requête :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    	SELECT colonne1 COLLATE maCollation,
    			colonne2 COLLATE maCollation
    	INTO temptable
    	FROM table1
    UNION 
    	SELECT colonne1 COLLATE maCollation,
    			colonne2 COLLATE maCollation
    	FROM table2
    mais cela ne fera que pourrir les performances de la requête.

    Dans les deux premiers cas, cela engendrera le recalcul de toutes les valeurs des colonnes de type chaîne de caractères...

    @++

  3. #3
    Membre confirmé Avatar de agemis31
    Profil pro
    DBA
    Inscrit en
    Octobre 2007
    Messages
    399
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : DBA

    Informations forums :
    Inscription : Octobre 2007
    Messages : 399
    Points : 478
    Points
    478
    Par défaut
    Bonsoir,


    Pour compléter la reponse d'elsuket, ceci vous permet d'afficher les collations et les niveaux de compatibilité de vos bases de données.

    Les bases intéressantes au niveau de votre union sont celle(s) contenant table1 et table2, et tempdb. Dans la mesure du possible, il faut avoir la même collation.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    select name, collation_name, compatibility_level from sys.databases
    select serverproperty('Collation')
    @+

  4. #4
    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 : 42
    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
    Attention :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT name, collation_name, compatibility_level FROM sys.databases
    fonctionne dès SQL Server 2005, mais pas sous SQL Server 2000.
    La table système sysdatabases ne le donnait pas.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT serverproperty('Collation')
    Fonctionne sous ces deux versions, tout comme :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT DATABASEPROPERTYEX('Collation')
    Qui donnera la collation de la base de données en cours.

    En revanche pour la colonne ...

    @++

  5. #5
    Membre du Club
    Étudiant
    Inscrit en
    Mars 2007
    Messages
    101
    Détails du profil
    Informations personnelles :
    Âge : 41

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2007
    Messages : 101
    Points : 64
    Points
    64
    Par défaut
    Bonjour,
    Avant tout je vous remercie pour toutes vos précieuses réponses, j'ai exactement essayer ce que vous m'avez donner mais sans pouvoir résoudre le problème!

    Ce qui est paradoxale c'est que lorsque j'exécute un select séparément (sans union) la requete marche sans soucis, mais le problème de collation est causé dés que j'introduit l'opérateur UNION entre les deux requetes avec le message :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Msg*468, Niveau*16, État*9, Ligne*31
    Cannot resolve the collation conflict between "French_CI_AI" and "SQL_Latin1_General_CP1_CI_AS" in the equal to operation.
    Prière de m'aider à résoudre ce problème

    Salutations

  6. #6
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 768
    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 768
    Points : 52 719
    Points
    52 719
    Billets dans le blog
    5
    Par défaut
    Commencez par postez INTÉGRALEMENT le texte ORIGINAL de votre requête.

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

Discussions similaires

  1. [débutant] erreur "indice de liste hors limites(1)"
    Par lidouka dans le forum Langage
    Réponses: 2
    Dernier message: 13/12/2005, 14h31
  2. [ODBC] erreur SQL pour les unions qui renvoient vide
    Par fabriceMerc dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 25/11/2003, 11h06

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