初めて投稿致します。
過去ログや他サイトでもいくつかみかけた事象ですが、
どこにもはっきりとした回答がないため質問させて頂きました。
知っている方がいたら、ご教授お願いします。
環境は、Win2003Server + SQL Server2000 です。
外部サーバからisqlで取得したデータをPerlでタブ区切りに加工し、
そのファイルをbcpでDBにインサートする処理でエラーが発生します。
エラー内容は、過去ログにもあったとおり
『文字列データの右側が切り捨てられました』というものです。
1行目からエラーが発生し、10回のエラー発生で異常終了します。
ただ、3万行あるデータを2万行と1万行にしてインサートすれば
問題なくDBに登録されます。
この事象はMicrosoftのバグなんでしょうか?
サイト上には、そのようなバグが報告されていないようですが。
それともどこかに仕様として紹介されているのでしょうか。
データのサイズ、レコード数に関わらず
bcpでインポートできるようにしたいのです。
ちなみに、現行は7.0で問題なく上記処理が稼動しています。
本サイト上に示されていた解決法のODBCバージョンですが、
ODBCは最新版が入ってるので、それ以外でこの事象の解決法を
知っている方がいましたらぜひとも教えてください。
以上、よろしくお願い致します。
No.2ベストアンサー
- 回答日時:
・件数次第で成功
・旧SQL-Serverでは成功
という2点で、やはりログファイル的にOKということなので、環境しか考えられないかと・・・
もちろんディスクはFATでフォーマットしてませんよね?
BCPIN最中に、セグメントがギュウギュウになってしまっているとか?
本当にログのフォーマットのせいではないですよね?
>外部サーバからisqlで取得したデータをPerlでタブ区切りに加工し、そのファイルをbcpでDBにインサートする処理でエラー
でも2万と1万に切り分けて成功する。。。
ならば、分割して入れたデータをTAB区切りでBCPOUTしてtruncate、さらにBCPINしても同じところでエラーが出ると思うのですがいかがでしょう?
同じところで出ているのであれば、
3万件のデータがどれほどのサイズであるかを知りたいです。
この回答への補足
>もちろんディスクはFATでフォーマットしてませんよね?
フォーマットはNTFSです。
>本当にログのフォーマットのせいではないですよね?
これはどういうことでしょうか?
ログのフォーマットによって何か起こるということでしょうか??
1050YENさんの言うように、
分割インサートしたデータをbcp outして再度bcp inしても同じ現象がでます。
単純にデータ件数に依存しているようです。
かなり細かくやっていくと、ある件数以上からはエラーが発生するようです。
ちなみにデータのサイズは50M前後です。
よろしくお願いします。
No.3
- 回答日時:
>>本当にログのフォーマットのせいではないですよね?
>これはどういうことでしょうか?
誤記です。すいません。
データのフォーマット(書式)と書きたかったのです。
perlということで、UNIX絡みと思われたので、エンコードやら何やらと思ったのですが、
>分割インサートしたデータをbcp outして再度bcp inしても同じ現象がでます。
ということから、根本のようですね。
私の現業務でSQL-Serverを利用しておりますが、同様な現象が発生しません。
ちなみに
データ:8万件
カラム数:41フィールド
です。
分割インサートしたデータをbcp outする時に、-tオプションを利用せず、-nでやっても一緒ですか?
perlで編集ができる文字ではなくなってしまいますが、それができないのであれば、環境としての根本的な話になってくると思います。
いろいろとお手数かけましたが、解決しました。
結論からいいますと、マイクロソフトのバグでした。
いろいろと調査した結果、英語版のサポートに修正パッチが公開されていて、それを適用で同様のエラーは発生しなくなりました。
ありがとうございました。
また、質問させていただきます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
10代と話して驚いたこと
先日10代の知り合いと話した際、フロッピーディスクの実物を見たことがない、と言われて驚きました。今後もこういうことが増えてくるのかと思うと不思議な気持ちです。
-
チョコミントアイス
得意ですか?不得意ですか?できれば理由も教えてください。
-
【お題】引っかけ問題(締め切り10月27日(日)23時)
【大喜利】 「日本で一番高い山は富士山……ですが!」から始まった、それは当てられるわけ無いだろ!と思ったクイズの問題
-
ちょっと先の未来クイズ第4問
11月ごろに発表される、2024年の「新語・流行語大賞」にノミネートされる言葉を書けるだけ書いてください。
-
ギリギリ行けるお一人様のライン
おひとり様需要が増えているというニュースも耳にしますが、 あなたが「ギリギリ一人でも行ける!」という場所や行為を教えてください
-
BCPでCSV内の文字列をテーブルのDatetime型カラムに取り込む方法
その他(データベース)
-
テーブル列数とデータファイル列数の違うbcpインサートをしたい
SQL Server
-
bcpインサートでのフォーマットファイルの書き方
SQL Server
-
-
4
バッチファイルからのBCP起動について
SQL Server
-
5
datetime型のインポートについて
SQL Server
-
6
バッチファイルからタスクスケジュールに値を返す
iOS
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・10秒目をつむったら…
- ・人生のプチ美学を教えてください!!
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
bcp in でエラー
-
SQLserver算術オーバーフロ...
-
Access VBAで行ラベルが定義さ...
-
日付書式に変換でこまっています!
-
Accessのマクロでモジュールを...
-
VBA プロシージャの名前の取得
-
エクセルVBA 今日の日付行...
-
EXCELでの時間計算(休憩時間の...
-
callで順に実行されるプロシー...
-
フォーム上で小計など自動計算...
-
ACCESS2007インポート時の空白...
-
Statement ignored というエラー
-
エクセルVBAでUserFormを起動し...
-
DB2のSELECTでカンマ編集につい...
-
likeとsubstrの使いわけについて
-
SQL*Plusの終了はquit?exit?
-
今日の日付が入った行のデータ...
-
SQLで部分的にGROUP BYしたいとき
-
キャッシュを使わずにSELECTを...
-
日付型カラムへのデータINSERT
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
SQLserver算術オーバーフロ...
-
bcp in でエラー
-
ストアドプロシージャのRETURN...
-
ACCESSのVBAでCSVを取込処理に...
-
Access VBAで行ラベルが定義さ...
-
Accessのマクロでモジュールを...
-
キャッシュを使わずにSELECTを...
-
エクセルVBAでUserFormを起動し...
-
Statement ignored というエラー
-
sqlplusでヘッダーが付かない
-
SQL*Plusの終了はquit?exit?
-
PL/SQLカーソルの2重FORループ...
-
全角空白のTRIMができない...
-
ODBCリンクの際にACCESSでは読...
-
VBA プロシージャの名前の取得
-
SQLで部分的にGROUP BYしたいとき
-
ストアドプロシジャからストア...
-
sqlplusのspoolで空白行出現
-
callで順に実行されるプロシー...
-
Transact-SQLでストアードプロ...
おすすめ情報