Java使用JDBC存储中文为问号问题

Java使用JDBC操作Mysql数据库存储中文为?

以前项目中都是使用Spring框架,最近突然需要写个Java程序,使用JDBC来操作数据库,居然发现不会了…存储中文总是显示???

Mysql数据库配置

创建的数据库就是UTF-8编码的
Java使用JDBC存储中文为问号问题_第1张图片

Eclipse文件编码设置

按照网上说的项目属性中的文件编码也设置成UTF-8
Java使用JDBC存储中文为问号问题_第2张图片

数据库连接代码

使用JDBC需要引入“mysql-connector-java-5.1.34.jar”库文件,连接代码如下:

try {
			Class.forName("com.mysql.jdbc.Driver").newInstance();
			conn = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/hz_db?useUnicode=true&characterEncoding=UTF-8", "root", "root");
			stmt = conn.createStatement();
			if (conn.isClosed())
				System.out.println("Failed to connect to database.");
			else
				System.out.println("Database connected.");
		} catch (SQLException e) {
			e.printStackTrace();
		} catch (Exception ex) {
			ex.printStackTrace();
		}

连接url中也设置characterEncoding=UTF-8了,为什么不起作用,但是读数据库时发现中文是正常的。
再仔细检查下url,突然发现了问题:

jdbc:mysql://127.0.0.1:3306/hz_db?useUnicode=true&characterEncoding=UTF-8

中间有个“& amp;”,这个url是直接从原来的xml配置文件copy过来的,而xml文件规定&必须转义为“& amp;”,但是我们这里直接使用就得替换为正常的&了。最终url如下:

jdbc:mysql://127.0.0.1:3306/hz_db?useUnicode=true&characterEncoding=UTF-8

这次终于中文写入正常了,看来对于程序员来说,copy需谨慎啊!!!

你可能感兴趣的:(基础知识)