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

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

新規登録して質問してみよう
ただいま回答率
85.46%
PostgreSQL

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

UTF-8

UTF-8は8ビット符号単位の文字符号化形式及び文字符号化スキームです。データ交換方式、ファイル形式としては、一般的にUTF-8が使われる傾向があります。

コマンド

コマンドとは特定のタスクを行う為に、コンピュータープログラムへ提示する指示文です。多くの場合、コマンドはShellやcmdようなコマンドラインインターフェイスに対する指示文を指します。

コマンドライン

コマンドライン(別名:Command Line Interface)は、ユーザに命令の入力を促す(プロンプト)文字列の表示を行い、すべての操作をキーボードを用いて文字列を打ち込む事でプログラムを走らせるユーザインターフェースです。

Q&A

解決済

1回答

2720閲覧

copy コマンドでPostgreSQLにCSVデータを読み込ませたい

退会済みユーザー

退会済みユーザー

総合スコア0

PostgreSQL

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

UTF-8

UTF-8は8ビット符号単位の文字符号化形式及び文字符号化スキームです。データ交換方式、ファイル形式としては、一般的にUTF-8が使われる傾向があります。

コマンド

コマンドとは特定のタスクを行う為に、コンピュータープログラムへ提示する指示文です。多くの場合、コマンドはShellやcmdようなコマンドラインインターフェイスに対する指示文を指します。

コマンドライン

コマンドライン(別名:Command Line Interface)は、ユーザに命令の入力を促す(プロンプト)文字列の表示を行い、すべての操作をキーボードを用いて文字列を打ち込む事でプログラムを走らせるユーザインターフェースです。

0グッド

0クリップ

投稿2021/09/07 05:47

編集2021/09/07 14:25

前提・実現したいこと

PostgreSQLにCSVファイルを読み込ませたいのですが、エラーが発生してうまくインポートできません。
データ元は.xlsで、CSVにして保存しました。

PostgreSQLにお詳しい方、ご教示頂けますと幸いです。
宜しくお願いいたします。

SQLは最近勉強し始めたばかりで、おかしなことを書いていたら申し訳ないです。

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

ERROR: character with byte sequence 0x87 0xe5 in encoding "SJIS" has no equivalent in encoding "UTF8" CONTEXT: COPY xxx, line 1

該当のソースコード

sql

1COPY xxx FROM '/Users/Uname/test.csv' WITH ENCODING 'sjis' HEADER CSV;

試したこと

UTF8のBOM付き?BOMなし等が原因かと変換など行いましたが特にエラーメッセージは変わりませんでした。

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

pc:mac (big sur 11.4)
言語:psql (PostgreSQL) 13.4
client encoding :UTF8

csvのデータ

http://xml.kishou.go.jp/tec_material.html
気象庁のリンクです。
”コード管理表一式(令和3年8月24日一部更新)
地震火山関連コード表.xls”をCSVに変更しています。
csv UTF-8(コンマ区切り)で保存しています。

csv

1Code,Name,ふりがな,Code,Name,ふりがな,Code,Name,ふりがな 2100,石狩地方北部,いしかりちほうほくぶ,0123500,石狩市,いしかりし,0123500,石狩市花川,いしかりしはなかわ 3100,石狩地方北部,いしかりちほうほくぶ,0123500,石狩市,いしかりし,0123501,石狩市聚富,いしかりししっぷ 4100,石狩地方北部,いしかりちほうほくぶ,0123500,石狩市,いしかりし,0123520,石狩市厚田,いしかりしあつた 5100,石狩地方北部,いしかりちほうほくぶ,0123500,石狩市,いしかりし,0123521,石狩市浜益,いしかりしはまます 6100,石狩地方北部,いしかりちほうほくぶ,0123500,石狩市,いしかりし,0123522,石狩市花畔,いしかりしばんなぐろ 7...以下省略します。

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2021/09/07 06:47

返信ありがとうございます。 はい、調べました。 クライアント側をSJIS等したりしましたが、解決に至らずこちらで初めて質問させていただきました。 質問分かりづらい書き込みで申し訳ないです。
FKM

2021/09/07 08:24

CSVファイルのエンコードは何ですか?postgreSQLは基本UTF-8にしか対応していないので、他言語を読み込ませる場合は一工夫必要となります。
YT0014

2021/09/07 08:25

test.csvの内容をご提示ください。
退会済みユーザー

退会済みユーザー

2021/09/07 14:22

FKMさん、YT 0014さん 返信ありがとうございます。 CSVを記載しました。 なるほど、UTF-8のみの対応なんですね。勉強になりました。 他言語を読み込む場合 ENCODING 'sjis' と、記述するのは間違っているのでしょうか?
FKM

2021/09/08 04:55

COPY xxx FROM '/Users/Uname/test.csv' WITH CSV; これでもだめでしょうか?
退会済みユーザー

退会済みユーザー

2021/09/08 05:34

返信ありがとうございます。  Header 付きCSVだったので、以下のコードを打ち込んだところ入ってくれました。 copy xxx from '/Users/Uname/text.csv' with csv header; 難しく考えすぎたようでした。 とても参考になりました。ありがとうございます。
FKM

2021/09/08 06:21

解決済みなら自己解決でクローズお願いします。
guest

回答1

0

ベストアンサー

header

sql

1copy xxx from '/Users/Uname/text.csv' with csv header;

投稿2021/09/08 06:24

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問