bcp कमांड 'p' के पास गलत सिंटैक्स। चरित्र वास्तव में है: "ä"


11

मेरे पास mssql- सर्वर और mssql- उपकरण उबंटू (लिनक्स) पर स्थापित हैं। जब मैं निम्नलिखित कमांड-लाइन का उपयोग करके bcp कमांड के साथ डेटा निर्यात करने का प्रयास करता हूं :

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

मुझे यह त्रुटि मिली:

SQLState = 37000, NativeError = 102
Error = [Microsoft] [SQL सर्वर के लिए ODBC ड्राइवर 13] [SQL सर्वर] ' ' के पास गलत सिंटैक्स।

है ä

अगर मैं Täble_Nameचौकोर कोष्ठकों से घिरा हूँ :

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

मुझे यह त्रुटि ऑब्जेक्ट नाम पर मिलती है:

SQLState = S0002, NativeError = 208
त्रुटि = [Microsoft] [SQL सर्वर के लिए ODBC ड्राइवर 13] [SQL सर्वर] अमान्य ऑब्जेक्ट नाम 'DBname.dbo.Täble_Name'।

मैं आगे गया और विकल्प ''के साथ एकल-उद्धरण जोड़े -q(जो कि कोटेड पहचानकर्ताओं को सक्षम करता है):

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

त्रुटि बन जाती है:

SQLState = S0002, NativeError = 208
त्रुटि = [Microsoft] [SQL सर्वर के लिए ODBC ड्राइवर 13] [SQL सर्वर] अमान्य ऑब्जेक्ट नाम 'DBname.dbo.T ble_Name'।

NB: कमांड इस विशेष चरित्र के बिना तालिका के नामों के साथ पूरी तरह से काम करता है।

जवाबों:


7

मेरा मानना ​​है कि यह शेल और bcp / SQL सर्वर के बीच एक एन्कोडिंग मुद्दा है । SQL सर्वर को उम्मीद है कि UTF-16 लिटिल एंडियन है, लेकिन लिनक्स उसका उपयोग नहीं कर रहा है। मेरे Linux VM के लिए डिफ़ॉल्ट UTF-8 है en_GB.UTF-8

<TL; DR> "क्वेरीआउट" bcp कमांड "SELECT * FROM ..."का उपयोग करें और "आउट" कमांड का उपयोग करने के बजाय निर्दिष्ट करें और बस एक टेबल नाम की आपूर्ति करें।

मेरा परीक्षण क्या है ...


मुझे उपलब्ध स्थानों / सूची का उपयोग करने की सूची मिली:

$ locale -a

लौटा हुआ:

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

मैंने सेटिंग करके उन विकल्पों में से कई आज़माए:

$ export LC_CTYPE=C.UTF-8

और फिर पुन: प्रयास कर रहा है:

$ export LC_ALL=C.UTF-8

कुछ भी फर्क नहीं लग रहा था। और हर बार जब मैंने स्क्वायर ब्रैकेट्स के विभिन्न संयोजनों को बिना -qऔर फिर साथ देने की कोशिश की -q, और फिर दोनों और बिना किसी वर्गाकार कोष्ठक के साथ नहीं -q

मैंने उन बाइट्स को भी इंजेक्ट करने की कोशिश की जो यूटीएफ -16 ले के चरित्र के äमाध्यम से $'\xe4\x00'और यहां तक ​​कि $'\xe4'$'\x00', लेकिन कोई सुधार नहीं होगा।

तथापि,

क्या किया था काम बदल रहा था BCP से आदेश outके बजाय करने के लिए हो सकता है queryout, और फिर बदलते तालिका नाम एक का हिस्सा बनने के SELECTबयान (मैं हटाया -r ~स्विच केवल यहाँ नहीं स्क्रॉल क्षैतिज कमांड लाइन बनाने के लिए, लेकिन यह मेरी परीक्षण में था)। मैंने तालिका बनाई [tempdb]और निम्नलिखित भाग गया:

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

वहां कोई समस्या नहीं। लेकिन दिलचस्प रूप से पर्याप्त, मैंने उच्चारण äको गैर-उच्चारण में बदल दिया a:

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

और निम्न त्रुटि प्राप्त हुई:

SQLState = S1000, NativeError = 0
त्रुटि = [Microsoft] [SQL सर्वर के लिए ODBC ड्राइवर 13] कॉलम स्तर के कोलाज को हल करने में असमर्थ

यह bcp से एक त्रुटि है और मेटा-डेटा के संदर्भ में होना चाहिए tempdbक्योंकि मेरी परीक्षा तालिका में एकमात्र कॉलम INTडेटाटाइप का उपयोग करता है ।

अब, मेरा उदाहरण-स्तर Collation उच्चारण-संवेदी है, इसलिए मैं वास्तव में गैर-उच्चारण aके काम करने की उम्मीद नहीं कर रहा था (हालांकि मैंने "अमान्य वस्तु" त्रुटि की अपेक्षा की थी)। इसलिए, उच्चारण-असंवेदनशीलता का परीक्षण करने के लिए, मैंने एक Collation के साथ एक नया डेटाबेस बनाया Latin1_General_100_CI_AI_KS_WS_CS, नए DB में उसी तालिका को बनाया, और कुछ पंक्तियों को जोड़ा। मैंने फिर निम्नलिखित दो परीक्षण किए:

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

और दोनों ने काम किया!

प्रारंभिक के लिए वापस जा BCP सिर्फ एक प्रश्न के बजाय तालिका नाम निर्दिष्ट करने के आदेश, मैं प्राप्त करने में सक्षम था ImportTest.dbo.[Table_Name]और ImportTest.dbo.Table_Nameकाम करने के लिए। हालाँकि, मैं अभी भी ImportTest.dbo.[Täble_Name]काम करने का कोई संयोजन नहीं पा रहा था ; सभी भिन्नताओं में पहले जैसी त्रुटियां थीं।

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.