java中向mysql数据库插入中文数据出现乱码

“java”中向“mysql”数据库插入中文数据时出现乱码的解决方法是:1、检查数据库的默认字符集和对应“database”的字符集;2、将整个数据库的默认字符集设置成“utf-8”;3、指定“JDBC”传输时使用“utf-8”编码。

java中向mysql数据库插入中文数据出现乱码

1、数据库插入中文乱码首先需要排除的问题是,MySQL的默认字符集和对应database的字符集是什么

通常为了以后的兼容性,建议将整个MySQL的默认字符集都设置成utf-8。可以使用以下命令查看默认字符集:

mysql> SHOW VARIABLES LIKE 'character%';
只听到从山间传来架构君的声音:
笑十三杨柳女儿腰,东风舞。有谁来对上联或下联?

建议对于新装的MySQL直接将整个所有的默认字符集都设置成utf-8,对于已经有很多database的可以单独设置特定的数据库的字符集。

学习视频推荐:java零基础入门

有关字符集的一些设置方法:

修改特定数据库的字符集

此代码由Java架构师必看网-架构君整理
mysql>use mydb mysql>alter database mydb character set utf-8;

创建数据库指定数据库的字符集

mysql>create database mydb character set utf-8;

2、指定JDBC在传输的时候使用utf-8编码

这样整个程序处理、传输、数据库存储都统一了编码格式,因此中文就不会乱码了。所以Java程序JDBC对应的数据库URL应该写成如下样式:

此代码由Java架构师必看网-架构君整理
// 驱动程序名 private static String driver = "com.mysql.jdbc.Driver"; // URL指向要访问的数据库名 private static String url = "jdbc:mysql://localhost:3306/watermarking?useUnicode=true&characterEncoding=utf-8"; // MySQL配置时的用户名 private static String user = "root"; // MySQL配置时的密码 private static String password = "root";

URL中“?”后面的就是指定使用UTF-8进行字符编码

更多java相关文章请关注:java编程入门

本文来源,由架构君转载发布,观点不代表Java架构师必看的立场,转载请标明来源出处:https://javajgs.com/archives/35593
0

发表评论