通过JDBC操作数据库表时,如果记录中有中文,可能会碰到乱码的问题。主要原因是字符编码(characterEncoding)不正确,包括以下几个方面:
- 在数据库服务器上创建表格时没有选择支持中文的编码方式;
- 建立JDBC连接时没有指明支持中文的编码方式;
建议在创建表格和建立JDBC连接时都采用utf-8编码。具体方法如下:
- 创建数据库表时,选择character与collation时都选utf-8
- 建立JDBC连接时在url中加入characterEncoding=utf-8,以MySQL为例代码如下:
1
2
3
4
5
Class.forName("com.mysql.jdbc.Driver").newInstance();
String url = "jdbc:mysql://localhost:3306/db1?characterEncoding=utf-8";
String dbUsername = "root";
String dbPassword = "root";
Connection conn = DriverManager.getConnection(url, dbUsername, dbPassword);