3

BCP を使用して、タブ区切りの *.txt ファイルから SQL テーブルにデータをインポートできません。

「キャスト指定の文字値が無効です」というエラーが 2 回発生します。

テストとして、いくつかの行を手動で挿入しました。次に、BCP でこれらの行を *.txt ファイルにクエリアウトします。次に、同じデータを BCP インポートしようとしました。

そのテストで、「キャスト仕様の無効な文字値」エラーと「BCP データファイルで予期しない EOF が発生しました」というエラーが表示されました。

どの行/列がエラーを引き起こしているかを知る方法はありますか?

BCP をデバッグするためのヒントや提案はありますか?

    #@ Row 1, Column 2: Invalid character value for cast specification @#
1003    1/2/2011 23:59:00   Neeta   Garg    <NULL>  8888    <NULL>  <NULL>  WESTBURY    NY  11594   US  ambulance   Yes Agency  92240099    000026  Neeta   Garg    <NULL>  8888    <NULL>  <NULL>  WESTBURY    NY  11594   US  2222222222  neeta@orderdynamics.com <NULL>  UPS GRD 42.650  AXB479T;67.5900;2|842000YEL;4.2900;22|B956N;51.8900;1|XSPSPCL;67.0000;1890300;2999.9900;1|B956N;51.8900;1|XSPSPCL;210.0000;1|59047BKLG;9.9900;1 AXB479T;|842000YEL;|B956N;Badge Custom Details :  Style = B956, Dimensions = 2  9/16\" x 2  9/16\", Enamel Type = regular, Font = block-black, Panel 2 = , Panel 3 = , Panel 5 = , Panel 6 = , Seal Style = , Attachment = NONE, Text Separator = NONE, Badge Comments = , badgeURL = http://www.blackinton.com/design-a-badge/data/pdf/vhbdab1291672350948.png, RESTXML = http://www.blackinton.com/design-a-badge/generate-xml.php?u=vhbdab1291672350948, Base Price = 59.00, Enamel = 0.00, Struck Solid = 0.00, Seal = 0.0  3271.8700   0.0000  0.0000  0.0000  3271.8700   1   Visa    <NULL>  0
1004    1/3/2011 23:59:00   Neeta   Garg    <NULL>  8888            WESTBURY    NY  11594   US  ambulance   Yes Agency  92240099    000026  Neeta   Garg        8888            WESTBURY    NY  11594   US  2222222222  neeta@orderdynamics.com     UPS GRD 0.000   AXB479T;67.5900;2|842000YEL;4.2900;22|B956N;51.8900;1|XSPSPCL;67.0000;1890300;2999.9900;1|B956N;51.8900;1|XSPSPCL;210.0000;1|59047BKLG;9.9900;1A161BK;115.9900;1    AXB479T;|842000YEL;|B956N;Badge Custom Details :  Style = B956, Dimensions = 2  9/16\" x 2  9/16\", Enamel Type = regular, Font = block-black, Panel 2 = , Panel 3 = , Panel 5 = , Panel 6 = , Sea
#@ Row 2, Column 2: Invalid character value for cast specification @#
1005    1/4/2011 23:59:00   Neeta   Garg    <NULL>  8888    <NULL>  <NULL>  WESTBURY    NY  11594   US  ambulance   Yes Agency  92240099    000026  Neeta   Garg    <NULL>  8888    <NULL>  <NULL>  WESTBURY    NY  11594   US  2222222222  neeta@orderdynamics.com <NULL>  UPS GRD 0.000   AXB479T;67.5900;2|842000YEL;4.2900;22|B956N;51.8900;1|XSPSPCL;67.0000;1890300;2999.9900;1|B956N;51.8900;1|XSPSPCL;210.0000;1|59047BKLG;9.9900;1A161BK;115.9900;1A161BK;115.9900;1   AXB479T;|842000YEL;|B956N;Badge Custom Details :  Style = B956, Dimensions = 2  9/16\" x 2  9/16\", Enamel Type = regular, Font = block-black, Panel 2 = , Panel 3 = , Panel 5 = , Panel 6 = , Seal Style = , Attachment = NONE, Text Separator = NONE, Badge Comments = , badgeURL = http://www.blackinton.com/design-a-badge/data/pdf/vhbdab1291672350948.png, RESTXML = http://www.blackinton.com/design-a-badge/generate-xml.php?u=vhbdab1291672350948, Base Price = 59.00, Enamel = 0.00, Struck Solid = 0.00, Seal = 0.0  115.9900    8.0000  0.0000  0.0000  123.9900    1   Visa    <NULL>  0
1006    2011-01-05 11:27:50.617 Neeta   Garg    <NULL>  8888            WESTBURY    NY  11594   US  ambulance   Yes Agency  92240099    000026  Neeta   Garg        8888            WESTBURY    NY  11594   US  2222222222  neeta@orderdynamics.com     UPS GRD 0.000   AXB479T;67.5900;2|842000YEL;4.2900;22|B956N;51.8900;1|XSPSPCL;67.0000;1890300;2999.9900;1|B956N;51.8900;1|XSPSPCL;210.0000;1|59047BKLG;9.9900;1A161BK;115.9900;1A161BK;115.9900;1A161BK;115.9900;1  AXB479T;|842000YEL;|B956N;Badge Custom Details :  Style = B956, Dimensions = 2  9/16\" x 2  9/16\", Enamel Type = regular, Font = block-black, Panel 2 = , Panel

日付を日時型として BCP インポートできないことがわかりました。したがって、型が varchar の一時テーブルにインポートしてから、必要なテーブルに SELECT INTO します。しかし、ターゲット テーブルの列の型が varchar であっても、無効な文字エラーが発生します。

#@ Row 1, Column 2: Invalid character value for cast specification @#
1003    2011-01-21 12:30:10.917 Neeta   Garg    <NULL>  8888    <NULL>  <NULL>  WESTBURY    NY  11594   US  ambulance   Yes Agency  92240099    000026  Neeta   Garg    <NULL>  8888    <NULL>  <NULL>  WESTBURY    NY  11594   US  2222222222  neeta@orderdynamics.com <NULL>  UPS GRD 42.650  AXB479T;67.5900;2|842000YEL;4.2900;22|B956N;51.8900;1|XSPSPCL;67.0000;1890300;2999.9900;1|B956N;51.8900;1|XSPSPCL;210.0000;1|59047BKLG;9.9900;1 AXB479T;|842000YEL;|B956N;Badge Custom Details :  Style = B956, Dimensions = 2  9/16\" x 2  9/16\", Enamel Type = regular, Font = block-black, Panel 2 = , Panel 3 = , Panel 5 = , Panel 6 = , Seal Style = , Attachment = NONE, Text Separator = NONE, Badge Comments = , badgeURL = http://www.blackinton.com/design-a-badge/data/pdf/vhbdab1291672350948.png, RESTXML = http://www.blackinton.com/design-a-badge/generate-xml.php?u=vhbdab1291672350948, Base Price = 59.00, Enamel = 0.00, Struck Solid = 0.00, Seal = 0.0  3271.8700   0.0000  0.0000  0.0000  3271.8700   1   Visa    <NULL>  0
1004    2011-01-21 12:30:10.917 Neeta   Garg    <NULL>  8888            WESTBURY    NY  11594   US  ambulance   Yes Agency  92240099    000026  Neeta   Garg        8888            WESTBURY    NY  11594   US  2222222222  neeta@orderdynamics.com     UPS GRD 0.000   AXB479T;67.5900;2|842000YEL;4.2900;22|B956N;51.8900;1|XSPSPCL;67.0000;1890300;2999.9900;1|B956N;51.8900;1|XSPSPCL;210.0000;1|59047BKLG;9.9900;1A161BK;115.9900;1    AXB479T;|842000YEL;|B956N;Badge Custom Details :  Style = B956, Dimensions = 2  9/16\" x 2  9/16\", Enamel Type = regular, Font = block-black, Panel 2 = , Panel 3 = , Panel 5 = , Panel 6 = , Sea
#@ Row 2, Column 2: Invalid character value for cast specification @#
1005    2011-01-21 12:30:10.917 Neeta   Garg    <NULL>  8888    <NULL>  <NULL>  WESTBURY    NY  11594   US  ambulance   Yes Agency  92240099    000026  Neeta   Garg    <NULL>  8888    <NULL>  <NULL>  WESTBURY    NY  11594   US  2222222222  neeta@orderdynamics.com <NULL>  UPS GRD 0.000   AXB479T;67.5900;2|842000YEL;4.2900;22|B956N;51.8900;1|XSPSPCL;67.0000;1890300;2999.9900;1|B956N;51.8900;1|XSPSPCL;210.0000;1|59047BKLG;9.9900;1A161BK;115.9900;1A161BK;115.9900;1   AXB479T;|842000YEL;|B956N;Badge Custom Details :  Style = B956, Dimensions = 2  9/16\" x 2  9/16\", Enamel Type = regular, Font = block-black, Panel 2 = , Panel 3 = , Panel 5 = , Panel 6 = , Seal Style = , Attachment = NONE, Text Separator = NONE, Badge Comments = , badgeURL = http://www.blackinton.com/design-a-badge/data/pdf/vhbdab1291672350948.png, RESTXML = http://www.blackinton.com/design-a-badge/generate-xml.php?u=vhbdab1291672350948, Base Price = 59.00, Enamel = 0.00, Struck Solid = 0.00, Seal = 0.0  115.9900    8.0000  0.0000  0.0000  123.9900    1   Visa    <NULL>  0
1006    2011-01-21 12:30:10.917 Neeta   Garg    <NULL>  8888            WESTBURY    NY  11594   US  ambulance   Yes Agency  92240099    000026  Neeta   Garg        8888            WESTBURY    NY  11594   US  2222222222  neeta@orderdynamics.com     UPS GRD 0.000   AXB479T;67.5900;2|842000YEL;4.2900;22|B956N;51.8900;1|XSPSPCL;67.0000;1890300;2999.9900;1|B956N;51.8900;1|XSPSPCL;210.0000;1|59047BKLG;9.9900;1A161BK;115.9900;1A161BK;115.9900;1A161BK;115.9900;1  AXB479T;|842000YEL;|B956N;Badge Custom Details :  Style = B956, Dimensions = 2  9/16\" x 2  9/16\", Enamel Type = regular, Font = block-black, Panel 2 = , Panel
4

1 に答える 1

13

ここでこのリンクを読みますhttp://luke.breuer.com/time/item/bcp_utility_gotchas/46.aspx

それは言います:

キャスト仕様の無効な文字値 bcp が列にアップロードしようとした値は、間違ったデータ型でした。最も単純なケースでは、整数以外の値を整数列にアップロードしたり、日付形式が正しくないなどの理由で発生します。ただし、{データ ファイルの列数} != {宛先テーブルの列数} /フォーマットファイル}. 列 # の不一致があるかどうかを確認する良い方法は、エラー ファイルが吐き出されるかどうかです (-e error.txt を使用しましたよね?)。

#@ 行 1、列 9: キャスト指定の無効な文字値 @#
2 0300 HC:36415 21 1 0 20070509 2
3 0300 HC:36415 21 1 0 20070608 2
#@ 行 2、列 9: キャスト指定の無効な文字値 @#
4 0301 HC:80076 366 1 0 20070509 2
5 0301 HC:80076 366 1 0 20070608 2

bcp が 2 行のデータをデータベースにアップロードする 1 行と見なすことに注意してください。これは、bcp が列区切り文字が {newline} である最後のものを除いて {tab} であることを認識しているためです。別の列が必要な場合は、{newline} のすぐ後ろを読み取ります。

日付形式が正しく記述されているかどうかも確認してください。http://support.microsoft.com/kb/883503

編集 2 - 1241PST

データベースが SQL Server であり、インポートしようとしている列のデータ型が datetime であると仮定すると、形式は次のようになります。

2011-01-21 12:30:10.917

私は一度この問題に遭遇したと思います...

フラット ファイル (タブ区切りの .txt) を EXCEL で開いてみて、そこから列を選択して形式を変更します。これを行うには、Excel の [データ] タブに移動し、列を選択し、[テキストから列へ] をクリックし、区切り記号を選択して終了します。すべての日付と時刻が表示されます。

次に、列を再度選択し、右クリックしてセルをフォーマットし、カテゴリ リストで DATE を選択して、フォーマットを SQL Server の期待される標準に変更する必要があります。それでも問題が解決しない場合は、テーブル/データベースを使用して単純で小さなテスト ケースをテストして、問題を絞り込んでみてください。

于 2011-01-21T17:30:41.527 に答える