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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Q&A

3回答

9878閲覧

【MYSQL】環境依存文字のInsertについて

suzuki_ayataka

総合スコア14

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

0グッド

1クリップ

投稿2016/11/03 14:12

###前提・実現したいこと
ここに質問したいことを詳細に書いてください
(例)PHP(CakePHP)で●●なシステムを作っています。
■■な機能を実装中に以下のエラーメッセージが発生しました。

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

エラーメッセージ

画面で入力した環境依存文字(例.髙)をmysqlに保存したいができない。
Incorrect string value: '\xFB\xFC\x95\xBD\x8D\x82...
となってしまい、insertができない。
mysql> SHOW VARIABLES LIKE 'character_set%';
+--------------------------+----------------------------------------+
| Variable_name | Value |
+--------------------------+----------------------------------------+
| character_set_client | sjis |
| character_set_connection | sjis |
| character_set_database | sjis |
| character_set_filesystem | binary |
| character_set_results | sjis |
| character_set_server | sjis |
| character_set_system | utf8 |
| character_sets_dir | /opt/cm610/mysql/share/mysql/charsets/ |
+--------------------------+----------------------------------------+

###該当のソースコード

ここにご自身が実行したソースコードを書いてください

javaでinsert文を実行しています。
// JDBCドライバのロード - JDBC4.0(JDK1.6)以降は不要
Class.forName("com.mysql.jdbc.Driver").newInstance();
// MySQLに接続
con = DriverManager.getConnection("jdbc:mysql://ip:3306/DB名?useUnicode=true&characterEncoding=sjis", "ユーザー", "パス");
String sql = "INSERT INTO テーブル名 ( idx,text )
+"VALUES( '9999999', '髙' );";
ResultSet result = stm.executeQuery(sql);

###試したこと
Sjisで保存したsqlファイルをLinux上に置き、
Linux上でsqlファイルを実行すると、mysqlに正しく保存されました。
###補足情報(言語/FW/ツール等のバージョンなど)
使用したドライバー:jdbc.Driver
カラム属性:longtext

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

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

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

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

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

guest

回答3

0

Windows10でローカルにおいたDBMS(MySQL 5.7.15)へのJavaクライアントからのアクセスで試してみました。

結論からいうとMySQLの文字セットを指定する様々な箇所の設定が全て、対象の文字を含む文字セットとなっていれば(必ずしもすべての文字セット設定が同一でなくても)問題なく格納・参照が可能ということのようです。指定可能な箇所にはコネクション、DB、テーブル、カラムなどいろいろあり、このうちどこかにこの文字を扱うのに不適切な文字セットがあるとエラーや文字化けに繋がります。質問者さんが挙げておられる文字'髙'についてはutf8/utf8mb4(UTF8), cp932(MS932)であればいずれを用いても格納できました(括弧の中は対応するJavaの文字セットです)。文字セットsjisだとだめのようです。

  1. MySQLのsjisとは?

MySQLのリファレンスページによると「sjis -> ShiftJIS Japanese」「cp932 -> SJIS for Windows Japanese」とあります。後者はJavaでのMS932であることがわかりますが、前者が何者なのか自分にはわかりませんでした。仮にIANAで規定されているShift-JISのことだと仮定するとIANAのShift-JISの説明ページにJIS X 0208の範囲内とありますので、JIS第一水準、第二水準の範囲になると思います。'髙'はJIS X 0208に割り当てがない文字なのでsjisは使えないことになります。

  1. どの文字セットがよさそうか

Windowsプラットフォームを使うならMySQLの文字コードとして使えそうなのはutf8mb4,utf8,cp932あたりになりそうです。Linux系だとcp932の代わりにEUC系(MySQLでの文字セット名は調べてません)のほうが都合がよいのかも知れません。一般的にはkm668さんがおっしゃるようにUnicodeベースのものを選択するのがよさそうです。Unicodeを選択しないのなら、使う必要のある文字を全て含むことを確認の上決めることになります。

余談:
文字セット名があちこち呼び名が違ってややこしいですね。MySQL内でcp932を選択するとそれはJavaではMS932と呼ばれ、MySQLのコネクションストリングの中でそれに該当する変換を指定したいとするとcp932ではなくms932と指定しなければなりません。またMySQLのutf8はJavaのUTF8のサブセットでありJavaのUTF8に相当するのがutf8mb4になっているとか・・・

投稿2016/11/04 07:11

KSwordOfHaste

総合スコア18394

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

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

0

文字コードがutf8 または utf8mb4 の環境なら問題は生じません。
CREATE TEMPORARY TABLE temp.test1 (col VARCHAR(8));
INSERT INTO temp.test1 VALUES ('髙');
SELECT * FROM temp.test1;
cp932(Shift-JIS)だと、逆斜線0x5Cが漢字に含まれるなどの煩わしい問題も残るので、
昔さんざん手を焼いた経験から言うと、utf8が最も安定しています。
文字コードの選択はmy.ini等のmysql環境設定ファイルに次の例のように指定するだけです。
[client]
default-character-set=utf8mb4
[mysql]
default-character-set=utf8mb4

投稿2016/11/03 19:51

km668

総合スコア65

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

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

退会済みユーザー

退会済みユーザー

2016/11/03 21:22

utf8mb4の対応はMySQL5.5からです。
guest

0

MYSQL:verは5.1.70

投稿2016/11/03 14:15

suzuki_ayataka

総合スコア14

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

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

KSwordOfHaste

2016/11/03 16:42

回答に書くのではなく、質問文を編集すべきと思います
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問