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!
Written by Sebastian
Related protips
4 Responses
data:image/s3,"s3://crabby-images/16cca/16cca1e0fd67e9cf3a0dd9cbebb5fca6eabe232d" alt=""
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);
}
data:image/s3,"s3://crabby-images/af4bf/af4bfa07d9af1c087b75ab5b3c2e9fd51394cba2" alt=""
Awesome it works for me & solve my proublem.
Thanks
Sachin
Our application reads dburl from xml file where the above jdbc change can't be inserted. What to do in such scenario?
data:image/s3,"s3://crabby-images/919bc/919bca68fd78cfe7ce4fd048a2f46752f1d592ff" alt=""
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();