[SQL Server]メッセージ 468、レベル 16、状態 9、照合順序の競合を解決できません。

[スポンサードリンク]

テーブル結合時などの照合順序の相違によるエラー

エラーメッセージ

メッセージ 468、レベル 16、状態 9、行 159
equal to 操作の “Japanese_CI_AS” と “Japanese_BIN2” 間での
照合順序の競合を解決できません。

コードの例(例えば)

原因

「売上テーブル」と「商品マスタ」の照合順序が違うため、商品コードを比較できない。

例えば、片方がSQL Serverのテーブルで、結合する側がOracleのテーブルをリンクサーバー経由、または他のSQL Serverのデータベースで、それぞれの照合順序が合っていない場合に起こる。

解決法

「COLLATE」を使用して、二つのテーブルの照合順序をどちらか一方に合わせる。

結合条件のあとの「COLLATE Japanese_BIN2」は今回の例でいえば「COLLATE Japanese_CI_AS」でも可。
エラーメッセージに書かれている照合順序のどちらかに合わせれば良い。

このようなコードをつけ足して対応するのは、本来良くないが、大規模なシステムで、このようなデータベースの作りになっているのなら、あきらめるしかない。

他にも、データベースに変更があってその変更済みのデータベースをもらうたびにそのテーブルだけ照合順序が違い。どちらかに合わせてくれと再三お願いしても逆切れされてあきらめてテーブルを作り直す場合もある。

[スポンサードリンク]

関連記事

コメント

  1. この記事へのコメントはありません。

  1. この記事へのトラックバックはありません。

CAPTCHA


ピックアップ記事

  1. 無料動画セミナー・クラスメンバとインスタンスメンバ (さらに…)…
  2. IDとパスワードでSQL Serverでログインするユーザーを作成する。 (さらに&hellip…
  3. SQLで月の末尾を求める方法。 (さらに…)…
  4. C言語のprintf関数でよく用いられるエスケープシーケンスを表すバックスラッシュ「\」の入力方法は…
  5. Oracle 12cではCDBとPDBの概念があるため、それより前のバージョンの様にログインすると、…

カテゴリー

[スポンサードリンク]




ページ上部へ戻る