通过Java向数据库写入中文数据变为问号的解决方法
在用Java写学生信息管理系统,在向向数据库添加数据时发现数据库里的中文数据变成的?
问题分析:
1.出现的问题:
程序运行正常无报错,系统添加功能部分实现(只能实现数字与字母的添加,添加中文数据时数据中数据会变成?)不使用Java程序插入直接在数据库中插入中文数据没有出现任何问题。
2.问题思考:
(1)添加数据只有中文数据出现了问题,初步判断为编码环境的问题
(2)数据库中有数据插入说明向数据库添加数据的代码没有问题
(3)在直接使用数据库添加数据时没有出现中文数据变为?的问题,说明数据库的编码形式没有错误。
小结:判断为数据库与java的编码环境不匹配
解决方法:
重新匹配数据库与java编码环境
java:
Java链接数据库的配置代码Url="jdbc:mysql://localhost:3306/***加上characterEncoding=utf-8
`Url="jdbc:mysql://localhost:3306/book?characterEncoding=utf-8";//链接数据库的地址
数据库:
在数据库的安装目录下找到my.ini文件
将文件中 character-set-server= Latin替换为character-set-server=utf8
测试:添加功能实现。成功添加中文数据