質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Windows 10

Windows 10は、マイクロソフト社がリリースしたOSです。Modern UIを標準画面にした8.1から、10では再びデスクトップ主体に戻され、UIも変更されています。PCやスマホ、タブレットなど様々なデバイスに幅広く対応していることが特徴です。

Oracle

Oracleは、米オラクルが取り扱うリレーショナルデータベース管理システムです。メインフレームからPCまで、多様なプラットフォームに対応しています。

Oracle Database 11g

Oracle DatabaseはRDBMSの商品です。具体的な発売商品として知られているのが、 Oracle9i、Oracle10g、Oracle 11gとOracle 12cです。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

PowerShell

Windows PowerShellはコマンドラインインターフェースであり、システム管理を含むWindowsタスク自動化のためのスクリプト言語です。

Q&A

解決済

3回答

19464閲覧

powershell から sqlplus を起動し、ファイルを指定してsqlを実行すると文字化けする

lolohacker

総合スコア31

Windows 10

Windows 10は、マイクロソフト社がリリースしたOSです。Modern UIを標準画面にした8.1から、10では再びデスクトップ主体に戻され、UIも変更されています。PCやスマホ、タブレットなど様々なデバイスに幅広く対応していることが特徴です。

Oracle

Oracleは、米オラクルが取り扱うリレーショナルデータベース管理システムです。メインフレームからPCまで、多様なプラットフォームに対応しています。

Oracle Database 11g

Oracle DatabaseはRDBMSの商品です。具体的な発売商品として知られているのが、 Oracle9i、Oracle10g、Oracle 11gとOracle 12cです。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

PowerShell

Windows PowerShellはコマンドラインインターフェースであり、システム管理を含むWindowsタスク自動化のためのスクリプト言語です。

0グッド

0クリップ

投稿2018/09/06 03:23

発生している問題・エラーメッセージ

powershellから

powershell

1sqlplus "[スキーマ名]/[パスワード]@[DBホスト名]" "@main.sql"

を実行して、テーブルへのインサートを実行すると、
カラムの値が文字化けしてしまいます。

文字化けさせないようにインサートを実行するにはどうすればよろしいでしょうか?
恐れ入りますが、ご教示お願い致します。

main.sql↓

@test001.sql @test002.sql exit

test001.sql、test002.sqlの中身は適宜テーブルへのインサート文です。

試したこと、確認したこと

  • .sqlファイルはいずれもUTF8 BOMなし
  • powershellで
set NLS_LANG=american_america.al32utf8

を実行してから上記のインサートを実施しても結果は同じだった。

補足情報(FW/ツールのバージョンなど)

SQL*Plus: Release 11.2.0.4.0 Production
Oracle Database 11g Release 11.2.0.3.0
DBサーバの'NLS_CHARACTERSET' → AL32UTF8

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

ベストアンサー

powershell なので環境変数の設定は

powershell

1$env:NLS_LANG = "american_america.al32utf8" 2```ではないでしょうか。

投稿2018/09/06 11:09

atata0319

総合スコア881

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

lolohacker

2018/09/07 00:19

回答ありがとうございます 文字化けはしているものの、出力結果が変わりました。 上記が影響しているのは確認できました。 色々試してみます。
lolohacker

2018/09/07 00:27

色々試しすぎて元のファイルがSJISになっていました。 UTF8に戻して実行したところ、文字化けせずにインサートされました。 ありがとうございました。
guest

0

cmd.exeから次のコマンドを入力してから再確認を...

chcp 65001

投稿2018/09/06 03:30

paolo.ahn

総合スコア73

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

lolohacker

2018/09/06 03:36

回答ありがとうございます 結果は同じく文字化けが発生しました
guest

0

set NLS_LANG=Japanese_Japan.AL32UTF8
で実行したらどうなりますか?

投稿2018/09/06 03:28

Orlofsky

総合スコア16415

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

lolohacker

2018/09/06 03:31

回答ありがとうございます 結果は同じく文字化けが発生しました
Orlofsky

2018/09/06 03:39

文字化けするのはマルチバイト文字の部分でしょうか?SQLをSJISで変更してスクリプトを実行したらどうなりますか?
lolohacker

2018/09/06 03:46 編集

「あいてむアイテムアイテム商品品番001001」という文字列が「縺ゅ>縺ヲ繧��スア�スイ�セ�セ代い繧、繝�繝�蝠�蜩∝刀逡ェ�シ撰シ撰シ�01」となります。SJISだと文字化けせずにインサートされました。今回はUTF8でなんとかしたいという所存です。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問