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

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

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

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

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

解決済

インサートしたデータが文字化けします。

sususu
sususu

総合スコア0

Java

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

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

1回答

0評価

0クリップ

6918閲覧

投稿2018/02/18 03:06

編集2022/01/12 10:58

連投で申し訳ありません。
下記のようなコードでデータをインサートしていますが、
データベースのテーブルの中身の日本語が文字化けしてしまいます。
(セレクト文でブラウザにつしても文字化けしています。)
開発環境
OS windows10
エディション enterprise
言語 java8.0.1310.11
MariaDB10.1
HeidiSQL
eclipse NEON

java

package test; import java.io.IOException; import java.io.PrintWriter; import java.sql.Connection; import java.sql.PreparedStatement; import javax.naming.InitialContext; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.sql.DataSource; import tool.Page; /** * Servlet implementation class Insert */ @WebServlet("/Insert") public class Insert extends HttpServlet { private static final long serialVersionUID = 1L; /** * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) */ protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // TODO Auto-generated method stub response.setCharacterEncoding("UTF-8");// PrintWriter out = response.getWriter(); Page.header(out); out.println("<meta charset = \"UTF-8\">");//HTML try{ InitialContext ic = new InitialContext(); DataSource ds = (DataSource)ic.lookup("java:comp/env/jdbc/localDB"); Connection con = ds.getConnection(); response.setCharacterEncoding("UTF-8");// String name = request.getParameter("name"); int price = Integer.parseInt(request.getParameter("price")); PreparedStatement st = con.prepareStatement("insert into product(id,name,price) values(null,?,?)"); con.setAutoCommit(true); st.setString(1, name); st.setInt(2,price); int line = st.executeUpdate(); if(line > 0){ out.println("追加に成功しました。"); } st.close(); con.close(); }catch(Exception e){ e.printStackTrace(out); } Page.footer(out); } }

今の文字データの設定
イメージ説明
そこで調べていたら下記のような記事を見つけました。
イメージ説明
しかしcp932への変更の仕方がわかりません。
show variables like "chara%";で表示させて直接変更しようとしたらエラーが出てしまいました。
当方MariaDBをGUIのみで操作しているのですがどこをいじれば変更できますでしょうか?
どなたかご回答よろしくお願いいたします。

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

unz.hori
unz.hori

2018/02/18 04:19

GUIで操作とは何を使っているのでしょうか?
sususu
sususu

2018/02/18 04:24

ご回答ありがとうございます!HeidiSQLというものになります!それすら記載できていなくて申し訳ありません!
unz.hori
unz.hori

2018/02/18 04:25

OSのバージョン、mariaDBのバージョンなど環境を詳しく書いた方が正しい回答が得られると思います。
sususu
sususu

2018/02/18 04:37

アドバイスありがとうございます!これからは下記の情報も追記して投稿するようにいたします!質問の仕方すら危うくて申し訳ありません!開発環境 OS windows10 エディション enterprise 言語 java MariaDB10\.1 HeidiSQL eclipse NEON
unz.hori
unz.hori

2018/02/18 04:40

Javaのバージョンも書いてください。また、コメントで返すのではなく、質問を編集して追記してください。文字化けはHeidiSQLで見たときのことでしょうか?
unz.hori
unz.hori

2018/02/18 04:41

質問に追記していただいてましたね。遅レスでした。
sususu
sususu

2018/02/18 05:23

更新させていただきました!
unz.hori
unz.hori

2018/02/18 05:25

"セレクト文でブラウザにつしても"の部分がよくわかりません。文字化けしている場面について詳しく書いてください。
sususu
sususu

2018/02/18 05:51

説明不足ですいません。文字化けしている結果画像を添付いたしました。
unz.hori
unz.hori

2018/02/18 07:02

化けていないデータはどうやって入れたんですか?
unz.hori
unz.hori

2018/02/18 07:07

逆にWeb側をUTF-8にするという発想もあると思いますが\.\.\.。HeidiSQLに文字コードを設定するオプション項目とかないですか?
sususu
sususu

2018/02/18 09:01

化けていないデータは手で入れた分になります。手で入れてAllで表示するとブラウザにもうつるので、データベースに入れるときの問題だと思っているのですが見つかりません????HeidiSQLの情報があまりネットに乗っていなくて困っています。引き続き探してみたいと思います。
asahina1979
asahina1979

2018/02/18 09:40

前回で解決したんじゃ
sususu
sususu

2018/02/18 11:03

HeidiSQLでデータベースに直接入れたデータを表示するのは文字化けしないようにできたのですが、javaの方からデータベースにインサートしたデータが文字化けしてしまいます。

まだ回答がついていません

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Java

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

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。