Last Updated: September 27, 2018
·
79.5K
· moezzie

JDBC: Inserting unicode UTF-8 characters into MySQL

Just a quick heads up if you're looking to insert for example Chinese characters into a MySQL database.

Case:

You're using JDBC to insert strings with unicode characters from your Java application and are seeing ??? or empty strings instead of 是 or 了in your database.

How to fix it:

First:
If your Java application is reading the data from for example a text file. Make sure you have specified the right characters encoding in your call to the input stream. It should look something like this:

BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(filePath), "UTF-8" )  );

Second:
Make sure you tell JDBC which encoiding to use. This is done as part of the query string when connecting to the DB.

Notice this part: ?useUnicode=yes&characterEncoding=UTF-8. This is where the magic happens.

Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/dbname?useUnicode=yes&characterEncoding=UTF-8","username", "password");

Third:
Ensure your table uses UTF-8. I usually go with "Encoding: UTF-8 Unicode(utf8)" and "Collation: utf8_bin"

Cheers,

May the code be with you!

4 Responses
Add your response

try {
Statement stmt;
ResultSet rs;
Class.forName("com.mysql.jdbc.Driver");
String url = "jdbc:mysql://localhost:3306/arabic?useUnicode=yes&characterEncoding=UTF-8";
Connection con = (Connection) DriverManager.getConnection(url, "root", "root");

   // con.setCharacterEncoding("utf-8");
    stmt = (Statement) con.createStatement();
    stmt.executeQuery("SET NAMES 'UTF8'");
    stmt.executeQuery("SET CHARACTER SET 'UTF8'");
    String greekname = "κωνσταντίνα";
    stmt.executeUpdate("INSERT INTO categories(category_id,category_name) VALUES ('" + 17 + "','" + greekname + "')");
    con.close();
} catch (Exception e) {
    System.out.println("problem during the connection with the database!"+e);
}
over 1 year ago ·

Awesome it works for me & solve my proublem.

Thanks
Sachin

over 1 year ago ·

Our application reads dburl from xml file where the above jdbc change can't be inserted. What to do in such scenario?

over 1 year ago ·

Will you can use "setNString " as show in Example
String Insr="Insert into PTTable "+"(PaID,Paname,PaAge,PaGender,PaDoctor,PaDate,TestID) VALues"+"(?,?,?,?,?,?,?)";

PreparedStatement stmt=(PreparedStatement)con.prepareCall(Insr);

 stmt.setInt(1, PaID);
 stmt.setNString(2,Paname);
 stmt.setInt(3, PaAge);
stmt.setNString(4, PaGender);
stmt.setNString(5,PaDoctor);
stmt.setDate(6, Padate);
stmt.setInt(7, TestID);
stmt.executeUpdate();
over 1 year ago ·