Commande bcp Syntaxe incorrecte près de ' '. Le personnage est en fait: "ä"


11

J'ai mssql-server et mssql-tools installés sur Ubuntu (Linux). Lorsque j'essaie d'exporter des données avec la commande bcp à l'aide de la ligne de commande suivante:

bcp DBname.dbo.Täble_Name out Täble_Name -c -k  -S127.0.0.1 -Usa -PpassWord -r ~

Je reçois cette erreur:

SQLState = 37000, NativeError = 102
Error = [Microsoft] [Pilote ODBC 13 pour SQL Server] [SQL Server] Syntaxe incorrecte près de ' '.

Le est ä.

Si j'entoure le Täble_Namede crochets:

 bcp DBname.dbo.[Täble_Name] out Täble_Name -c -k  -S127.0.0.1 -Usa -PpassWord -r ~

J'obtiens cette erreur sur le nom de l'objet:

SQLState = S0002, NativeError = 208
Erreur = [Microsoft] [Pilote ODBC 13 pour SQL Server] [SQL Server] Nom d'objet non valide 'DBname.dbo.Täble_Name'.

Je suis allé plus loin et j'ai ajouté des guillemets simples ''avec l' -qoption (qui active les identifiants entre guillemets ):

bcp 'DBname.dbo.[Täble_Name]' out Täble_Name -c -k  -S127.0.0.1 -Usa -PpassWord -r ~ -q

L'erreur devient:

SQLState = S0002, NativeError = 208
Error = [Microsoft] [Pilote ODBC 13 pour SQL Server] [SQL Server] Nom d'objet non valide 'DBname.dbo.T ble_Name'.

NB: la commande fonctionne parfaitement avec les noms de table sans ce caractère spécial ä.

Réponses:


7

Je crois que c'est un problème d'encodage entre le shell et bcp / SQL Server. SQL Server attend UTF-16 Little Endian, mais Linux ne l'utilise pas. La valeur par défaut pour ma machine virtuelle Linux est UTF-8 via en_GB.UTF-8.

<TL; DR> Utilisez la commande bcp "queryout" et spécifiez "SELECT * FROM ..."au lieu d'utiliser la commande "out" et de simplement fournir un nom de table.

Ce qui suit est mon test ...


J'ai obtenu la liste des locales / encodages disponibles en utilisant:

$ locale -a

revenu:

C
C.UTF-8
en_AG
en_AG.utf8
en_AU.utf8
en_BW.utf8
en_CA.utf8
en_DK.utf8
en_GB.utf8
en_HK.utf8
en_IE.utf8
en_IN
en_IN.utf8
en_NG
en_NG.utf8
en_NZ.utf8
en_PH.utf8
en_SG.utf8
en_US.utf8
en_ZA.utf8
en_ZM
en_ZM.utf8
en_ZW.utf8
POSIX

J'ai essayé plusieurs de ces options en définissant:

$ export LC_CTYPE=C.UTF-8

puis réessayez en utilisant:

$ export LC_ALL=C.UTF-8

Rien ne semblait faire de différence. Et à chaque fois, j'ai essayé avec différentes combinaisons de crochets sans -qet puis avec -q, puis sans crochets avec et sans -q.

J'ai même essayé d'injecter les octets qui équivaudraient au caractère UTF-16 LE de ävia $'\xe4\x00'et même $'\xe4'$'\x00', mais aucune amélioration.

CEPENDANT,

ce qui a fonctionné a été de changer la commande bcp de outà la place queryout, puis de changer le nom de la table pour faire partie d'une SELECTinstruction (j'ai supprimé le -r ~commutateur uniquement ici pour que la ligne de commande ne défile pas horizontalement, mais c'était lors de mes tests). J'ai créé la table [tempdb]et exécuté ce qui suit:

bcp "SELECT * FROM tempdb.dbo.[Täble_Name]" queryout tab -c -k -S127.0.0.1 -Usa -Ppass

Aucun problème là-bas. Mais chose intéressante, j'ai changé l'accent äavec un accent non a:

bcp "SELECT * FROM tempdb.dbo.[Table_Name]" queryout tab -c -k  -S127.0.0.1 -Usa -Ppass

et a reçu l'erreur suivante:

SQLState = S1000, NativeError = 0
Erreur = [Microsoft] [Pilote ODBC 13 pour SQL Server] Impossible de résoudre les classements au niveau des colonnes

C'est une erreur de bcp et doit faire référence aux métadonnées de tempdbpuisque la seule colonne de ma table de test utilise le INTtype de données.

Maintenant, mon classement au niveau de l'instance est sensible à l'accent, donc je ne m'attendais pas vraiment à ce que le non accentué afonctionne (bien que je m'attendais à une erreur "objet non valide"). Ainsi, afin de tester l'insensibilité aux accents, j'ai créé une nouvelle base de données avec un classement de Latin1_General_100_CI_AI_KS_WS_CS, créé cette même table dans la nouvelle base de données et ajouté quelques lignes. J'ai ensuite exécuté les deux tests suivants:

bcp "SELECT * FROM ImportTest.dbo.[Täble_Name]" queryout tab -c -k  -S127.0.0.1 -Usa -Ppass

bcp "SELECT * FROM ImportTest.dbo.[Table_Name]" queryout tab -c -k  -S127.0.0.1 -Usa -Ppass

et les deux ont fonctionné!

Pour en revenir à la commande bcp initiale de simplement spécifier le nom de la table au lieu d'une requête, j'ai pu obtenir ImportTest.dbo.[Table_Name]et ImportTest.dbo.Table_Nametravailler. Cependant, je n'ai toujours pas réussi à obtenir une combinaison de ImportTest.dbo.[Täble_Name]travail; toutes les variantes ont les mêmes erreurs qu'auparavant.

En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.