首页 > 数据库 >用Java开发出网站,在其中输入中文,但是保存到MySQL数据库中却是????

用Java开发出网站,在其中输入中文,但是保存到MySQL数据库中却是????

时间:2022-12-30 10:34:00浏览次数:41  
标签:中文 set Java 数据库 MySQL 字符集 修改 mysql


前言:

前两部分是从mysql和eclipse的角度去解决,在解决的过程中学到了之前没设计到的查看和修改数据库或数据表的字符集的知识。

后一部分是掌握了前两步后,进行的新一轮解决问题的探索。其中遇到的细枝末节的bug,也一一解决,最终解决的方法是过在mysql控制台设置数据库的字符集为gbk解决的。但是前两部分的学习,我觉得还是值得了解的。

文章目录

  • ​​前言:​​
  • ​​mysql 存储中文显示??,如何解决​​
  • ​​方法一:改数据库编码​​
  • ​​方法二:改数据表编码。(Navicat中)​​
  • ​​方法三:修改数据表编码。(在MySQL中)​​
  • ​​eclipse连接MySQL存储中文显示??​​
  • ​​方法一:改eclipse配置文件​​
  • ​​方法二:修改MySQL配置文件​​
  • ​​乱码表现,用Java开发出网站,在其中输入中文,但是保存到MySQL数据库中却是????。​​
  • ​​1先解决在MySQL中插入看能不能插入;​​
  • ​​2处理1366报错。​​
  • ​​3eclipse动态网站项目,输入中文,保存到数据库就显示??​​
  • ​​4MySQL5.5闪退,Navicat报出2003错误​​
  • ​​mysql5.5闪退​​
  • ​​出现新的问题:text类别不能显示​​
  • ​​Mysql出现无限回车,无法执行命令;​​
  • ​​接着处理text类别的问题。​​
  • ​​完结撒花*********************​​

mysql 存储中文显示??,如何解决

前言:做毕业设计的时候,mysql5.5不知道为什么存储中文显示??。于是开始了下面的尝试。

方法一:改数据库编码

教程:​​mysql 存储中文显示???,通过修改my.ini解决​​

结果:没用,继续???。前两步没问题,但是第三步的时候应该是版本的原因,我的是mysql5.5,博主的是mysql5.7。我的my.ini文件中client中没有设置不管用。

收获:这个指令挺好用的(查看数据库当前编码):show variables like ‘%character%’;

方法二:改数据表编码。(Navicat中)

教程:mysql,不能插入中文怎么办?

结果:有的有用(在Navicat中用控制台可以插入),有的没用(在mysql中不能插入)。

收获:也算是成功了一半,至少在mysql中虽然不能插入,但是能用Navicat插入,用mysql显示。

注意事项:1注意保存。

2最好提前写好插入的测试语句,不然每次试都要写一次。如

insert t_user (userName, loginName, password, status, roleId) values (‘开心’,‘kaixin’,‘kaixin’,‘2’,1);

insert t_news (newsId,title,content,categoryId) values (73,‘kaix开心’,‘kaixin开心’,2);

方法三:修改数据表编码。(在MySQL中)

教程:​​mysql 插入中文 ERROR 1366 (HY000): Incorrect string value: ‘\xE7\x8E\x9E\x97’ for column​​

结果:依然不行。

收获:了解到了1366报错。对查看和修改数据库或数据表的字符集的mysql知识进行了补充。show full fields from news指令来查看表的字符集挺好用的。

eclipse连接MySQL存储中文显示??

方法一:改eclipse配置文件

教程:​​eclipse插入数据到MySQL数据库时,出现中文乱码问题的解决方法​​

结果:无用

收获:对eclipse连接mysql出现中文乱码的解决方法之一有了一个了解,虽然这个对我没用。

方法二:修改MySQL配置文件

教程:​​mysql如何更改character-set-server默认为latin1​​

结果:部分有用,部分没用;5.5版本和5.7版本不一样;综合了上一个问题的方法一和方法三。要么在mysql中修改mysql的配置,但是这个是短期的,下次打开又得重新设置;要么修改mysql的my.ini。可以在mysql中修改字符集配置好说,但是修改my.ini就根据版本不同有不同的修改。

收获:对mysql的字符集配置有了更深的理解。

经验:把修改数据表的字符集的命令保存到文档,用的时候复制,不然每次打有些麻烦。

set character_set_database=utf8;

set character_set_server=utf8;

set character_set_database=gbk;

set character_set_server=gbk;

set character_set_client=gbk;

set character_set_connection=gbk;

set character_set_results=gbk;

随笔:

在Navicat中有用,在MySQL中报错;

ERROR 1366 (HY000): Incorrect string value: ‘\xBF\xAA\xD0\xC4’ for column ‘userName’ at row 1

查看mysql的字符集:show variables where Variable_name like ‘%char%’;

查看某一个数据库字符集:show create database enterprises;(注:enterprises为数据库)

查看某一个数据表字符集:show create table employees;(注:employees为数据表)

梳理过程:

补充一个字符集的知识点:​​gbk与utf8​​

乱码表现,用Java开发出网站,在其中输入中文,但是保存到MySQL数据库中却是????。

这一部分是回顾整理前两个问题,然后推到下一步怎么办。

1先解决在MySQL中插入看能不能插入;

用Navicat中的操作,修改数据表的字符集为utf8;

参考教程:mysql,不能插入中文怎么办?

还挺有用的,在Navicat中使用终端输入的时候可以输入中文显示中文;

但是又出现两个新的问题,

第一个是在MySQL仍然不能插入,报出1366错误;

ERROR 1366 (HY000): Incorrect string value: ‘\xBF\xAA\xD0\xC4’ for column ‘userName’ at row 1

第二个错误是在Navicat可以正常显示中文,但是在MySQL中不能显示。

2处理1366报错。

方法一:修改数据库的字符集,在直接修改my.ini。

​​mysql 存储中文显示???,通过修改my.ini解决​​

不可行,可能和版本有关系,我的是5.5版本,教程的版本是5.7;MySQL5.5好像就是不能修改server和database的字符集。这两个的字符集一直都是Latin1;

方法二:修改数据库的字符集,在MySQL中用语句修改,修改字符集为gbk;

参考教程:​​ERROR 1366 (HY000):Incorrect string value解决方案(亲测)​​

误打误撞把显示问题显示问题解决了,把utf8编码改为gbk就可以在MySQL正常显示。

同时用MySQL修改server和database的字符集后,还真的可以输入了。

虽然重启之后,这个server和database又是latin1;但是还是可以输入中文的。

然后我到Java中输入中文,看保存在MySQL是不是中文,结果还是显示??。我估计和我之前把eclipse中的字符集设置为utf8有关。或者和之前只在控制台修改,没有在my.ini中修改有关。在控制台中修改是临时修改,不能根治。但是我的MySQL5.5就是不能修改client和mysqld的默认字符集,设置了不起作用,在显示中,server和database仍然是latin1.或许我该装MySQL5.7.

3eclipse动态网站项目,输入中文,保存到数据库就显示??

创建数据库的时候把字符集设为utf8,保证前端页面编码格式也为UTF-8;

参考教程:​​解决:JavaWeb项目中向数据库插入中文数据时出现乱码问题​​

无解,我在my.ini中把字符集设为utf8后,MySQL又开始乱码,所以MySQL5.5中只能设置为gbk.。故此方法仅供参考,我再去想想其他办法。

4MySQL5.5闪退,Navicat报出2003错误

mysql5.5闪退

参考教程:MySQL5.5闪退解决方法

这一部分是最终版本,请仔细看到最后,就知道怎么解决

比较莫名其妙,不过我想应该是我设置的my.ini起作用了,之前的那些操作误打误撞使问题解决了。此时我的感受

用Java开发出网站,在其中输入中文,但是保存到MySQL数据库中却是????_mysql

我的MySQL存在C盘,所以用cd…来退出目录,最后用 cd C:\Program Files\MySQL\MySQL Server 5.5\bin 进入MySQL客户端的目录。

有效。退出后,再用client登录没有闪退了。

莫名其妙server和database设置成了gbk;

莫名其妙问题解决了,在eclipse中输入中文可以保存到数据库中,并且没有乱码。

出现新的问题:text类别不能显示

介绍text类别:​​mysql中char,varchar与text类型的区别和选用​​

第二天又闪退,然后用第一天的方法操作,再次可行,但是每次都需要自己启动MySQL,觉得好像不能根治。并且database居然变成了latin1,

Mysql出现无限回车,无法执行命令;

网上说是用中文分号结尾导致的,也不知道是不是;

然后用’\c结束这个;有效。

接着处理text类别的问题。

好难找到解决方法,难道没人遇到这个问题?

唯一的一个回答是set names utf8;

我的设置的是gbk,所以我尝试用set names gbk;试试,没用;

show full fields from t_news;

发现我的content中的text类别的collation是latin1_swedish_ci;所以我需要把这个改为utf8_general_ci。

alter table t_news change content content text character set “utf8”;

僵硬,无效,连之前有效的类别都不能插入中文了;可能和我set names utf8;有关

于是我重新把所有的都从头设置一遍。全部设置为gbk。结果解决了


标签:中文,set,Java,数据库,MySQL,字符集,修改,mysql
From: https://blog.51cto.com/u_15847108/5979195

相关文章

  • 纯JavaScript入门级小游戏:兔子抢金币(附演示地址+源码)
    Hello,大家好,我是兔哥,我又来分享好玩的入门级项目啦。今天给大家带来的是一个纯JavaScript入门级小游戏:兔子抢金币,规则非常简单,控制屏幕上的兔子去接天上掉下来的金币,接满20......
  • 送书啦,JavaScript百炼成仙,第一轮送书抽奖活动
    ......
  • 锦囊秘籍!用Python操作MySQL的使用教程集锦!
    一.python操作数据库介绍大家好,我是毕加锁(锁!)。Python标准数据库接口为PythonDB-API,PythonDB-API为开发人员提供了数据库应用编程接口。Python数据库接口支持非常多的......
  • Mysql索引覆盖
    作者:孙涛1.什么是覆盖索引通常情况下,我们创建索引的时候只关注where条件,不过这只是索引优化的一个方向。优秀的索引设计应该纵观整个查询,而不仅仅是where条件部分,还应该关注......
  • Mysql索引覆盖
    作者:孙涛1.什么是覆盖索引通常情况下,我们创建索引的时候只关注where条件,不过这只是索引优化的一个方向。优秀的索引设计应该纵观整个查询,而不仅仅是where条件部分,还应该......
  • 老杜告诉你java小白到大神是怎么炼成的
    1.学习前的准备1.1一个好的学习方法(应该怎么学习更高效);一个合格的程序员应该具备两个能力有一个很好的指法速度(敲代码快)有一个很好的编程思想(编程思路:能够使用编程......
  • 启动Java项目报错Problematic frame:Failed to write core dump. Minidumps are not e
    ❗Problematicframe:有问题的框架✔fastjson空指针不能正确抛空指针异常,换成fastjson2即可。AfatalerrorhasbeendetectedbytheJavaRuntimeEnvironment:EXC......
  • 关系型数据库 和 非关系型数据库
    1、关系型数据库概述关系型数据库,被称为SQL,是一个结构化的数据库,创建在关系模型(二维表格模型)基础上,一般面向于记录。其以行和列的形式存储数据,以便于用户理解,关系型数据......
  • Mysql数据库查看Database的大小的方法
    最简单的方法为:selectconcat(round(sum(data_length/1024/1024),2),'MB')asdatafromINFORMATION_SCHEMA.tableswheretable_schema='XXXXX2206'; 另外发现备......
  • 10Javascript高级
    JavaScript面向对象目标:能够说出什么是面向对象能够说出类和对象的关系能够使用class创建自定义类能够说出什么是继承面向对象编程介绍:两大编程思想:面向过程面向对象面向过......