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

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

新規登録して質問してみよう
ただいま回答率
85.35%
シェルスクリプト

シェルスクリプトは、UNIX系のOSもしくはコマンドラインインタプリタ向けに記述されたスクリプト。bash/zshといったシェルによって実行されるため、このように呼ばれています。バッチ処理などに使用されており、テキストファイルに書かれた命令を順に実行します。

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

SQL

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

Q&A

2回答

8719閲覧

PSQLの結果をcsvで出力するファイルの文字コードをUTF-8にしたい

SH_1174

総合スコア10

シェルスクリプト

シェルスクリプトは、UNIX系のOSもしくはコマンドラインインタプリタ向けに記述されたスクリプト。bash/zshといったシェルによって実行されるため、このように呼ばれています。バッチ処理などに使用されており、テキストファイルに書かれた命令を順に実行します。

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

SQL

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

0グッド

0クリップ

投稿2021/11/04 05:49

編集2021/11/04 07:08

シェルスクリプトでPSQLコマンドの結果をCSVでUTF-8で出力したいのですが、デフォルトだとShift-jisになってしまいます。
実現案のために文字コード変換のコマンドを流しているのですが、ファイルの中身が削除されかつUTF-8に変換されずに困っています。

以下コマンドになります。

psql -U ユーザ名 -d データベース -h ホスト名 -p ポート番号 -f "select.sql" -t -A -F, >> AAAAA_YYMMDD.csv
iconv -f cp932 -t UTF-8 AAAA_YYMMDD.csv > AAAA_YYMMDD.csv

PSQLの結果出力時にUTF-8で出力するようなオプション等はあるのでしょうか。

もしくは上記コマンド以外にファイルの中身を削除せず、変換できるコマンドはあるのでしょうか。

初歩的な質問で申し訳ありませんが、どなかたお知恵をお貸しください。

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

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

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

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

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

melian

2021/11/04 06:06

incov -f cp932(Shift-jis) -t ... と書かれていますが、iconv -f cp932 -t ... の書き間違いでしょうか?
SH_1174

2021/11/04 06:53

書き間違えです。 失礼致しました。 コード内容を修正しました。
melian

2021/11/04 07:04

-f cp932(Shift-jis) の部分も間違えていますが…まぁ、それはさておいて、文字コード云々の問題ではなく、同じファイルに変換結果を書き出していることが問題です。
SH_1174

2021/11/04 07:14

同じファイルだとだとダメなんですね。。。 ありがとうございます! 一旦別ファイルに変換結果を出力するようにしてみましたが、やはりUTF-8にはなりませんでした。。。
melian

2021/11/04 07:19

出力した別ファイルの文字コードが UTF-8 になっていない、ということですか?
SH_1174

2021/11/04 07:33 編集

はい。出力した別ファイルがUTF-8になっていない状態です。
guest

回答2

0

ああ、あなたがこのトピックを取り上げてくれたのは幸運です。私は実際に同じことについて疑問に思っています。私はそれを機能させる方法についてさまざまな方法を試してきましたが、まだそれをしていません。皆さんはこれに対する解決策をもう見つけましたか?

投稿2021/11/08 01:54

smuasher

総合スコア26

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

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

0

psqlのメタコマンド

\encoding UTF8

を使う方法もあります。
入出力の文字セットが指定のものに切り替わります。
psqlに与えるsqlファイルの冒頭に記述しておくと良いかと存じます。

psql

投稿2021/11/05 02:39

編集2021/11/05 02:40
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問