草庐IT

MySQL 5.7中文乱码与远程链接问题

Jack魏 2023-03-28 原文
(MySQL 5.7中文乱码与远程链接问题)

1. MySQL 5.7中文乱码

当我们直接在数据库里面输入中文时,保存后出现: Incorrect string value:‘\xE9.....’ for column '' at row 1

出现上面的原因是因为字符编码设置有问题: 我们右击表设计,查看一下对应的字段: 可以看到字符集是latin1,我们可知MySQL5.7版本默认字符编码是latin1 这个字符集是不支持中文的,那我们怎么支持中文呢? 支持中文的有:GBK、UTF8、UTF8mb4等 目前比较常用的是UTF8了,如果是有表情特殊字符需要用到UTF8mb4。 因为他们底层使用的存储大小不同:

字符编码 所占大小(字节)
latin1 1
gb2312 2
gbk 2
utf8 3
utf8mb4 4
PS:MySQL8.0之后默认就是utf8mb4 字符集了。

也可以使用语句查询:

SHOW CHARACTER SET; 所有我要修改一下默认字符集, 需要到C:\ProgramData\MySQL\MySQL Server 5.7下面修改my.ini文件。 默认情况下可以从上面查找。 如果不知道可以运行如下命令查看:

# 查看运行程序目录 select @@basedir; # 查看数据库存储(配置文件在此上一层) select @@datadir;

然后添加如下内容: 注意中括号里面的是配置其下面,不要复制过去。

[client] default-character-set=utf8 [mysql] # 配置默认字符集 default-character-set=utf8 [mysqld] # 配置字符集和排序 character-set-server=utf8 collation-server=utf8_general_ci 查看是否设置成功, 这个时候一定要注意,之前新建的数据库还是原来的字符集需要新建数据库才能更改成默认的,如果不想新建需要一个一个修改指定的字段即可。

show VARIABLES like '%character%'

2. 远程链接问题

当我们本地电脑连接本地的数据库时是没有问题的, 如果是在一个局域网内,其他电脑访问就有问题了, 说明没有开启远程链接权限。 参考文档:MySQL远程登录授权

# 允许root远程链接,并通过指定密码验证 grant all privileges on *.* to root@'%' identified by '123456'; 执行完一下语句,其他电脑即可远程链接了。

3. 不区分表大小写

Windows默认是区分大小写的, 这时候需要修改MySQL的配置my.ini文件 , 需要在mysqld节下加入:

[mysqld] # 配置表名不区分大小写 lower_case_table_names=1

4. 超过最大连接数

如果你的MySQL服务器作为其他电脑的连接服务器, 有可能会出现连接超过最大连接数

show global variables like 'max_connect%'; 执行上面的语句,我们可以看到到达100就会报错了。 所以我们要修改一下最大连接数。 解决方案:在mysqld下面添加如下设置

[mysqld] max_connections = 2000

5. 时区问题

参考文档:MySQL如何修改时区 可以看到默认采用系统的时区,但是有可能系统时区有问题。

[mysqld] default-time_zone = '+8:00'

5. GROUP BY 问题

参考文档:Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column xxxxx

[mysql] # Group by会用到 sql-mode="STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION" [mysqld] # Group by会用到 sql-mode="STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"

配置集合

[client] default-character-set=utf8 [mysql] # 配置默认字符集 default-character-set=utf8 # Group by会用到 sql-mode="STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION" [mysqld] # 默认时区 default-time_zone = '+8:00' # 配置字符集和排序 character-set-server=utf8 collation-server=utf8_general_ci # 服务端口 port=3306 # 主从id server-id=1 # 配置表名不区分大小写 lower_case_table_names=1 # 最大连接数 max_connections=2000 # 数据库存储地址 datadir=C:/ProgramData/MySQL/MySQL Server 5.7/Data # 存储引擎 default-storage-engine=INNODB # Group by会用到 sql-mode="STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"

重启MySQL

经过上面的配置之后,需要重启MySQL:

有关MySQL 5.7中文乱码与远程链接问题的更多相关文章

  1. ruby - 在 64 位 Snow Leopard 上使用 rvm、postgres 9.0、ruby 1.9.2-p136 安装 pg gem 时出现问题 - 2

    我想为Heroku构建一个Rails3应用程序。他们使用Postgres作为他们的数据库,所以我通过MacPorts安装了postgres9.0。现在我需要一个postgresgem并且共识是出于性能原因你想要pggem。但是我对我得到的错误感到非常困惑当我尝试在rvm下通过geminstall安装pg时。我已经非常明确地指定了所有postgres目录的位置可以找到但仍然无法完成安装:$envARCHFLAGS='-archx86_64'geminstallpg--\--with-pg-config=/opt/local/var/db/postgresql90/defaultdb/po

  2. ruby - 通过 rvm 升级 ruby​​gems 的问题 - 2

    尝试通过RVM将RubyGems升级到版本1.8.10并出现此错误:$rvmrubygemslatestRemovingoldRubygemsfiles...Installingrubygems-1.8.10forruby-1.9.2-p180...ERROR:Errorrunning'GEM_PATH="/Users/foo/.rvm/gems/ruby-1.9.2-p180:/Users/foo/.rvm/gems/ruby-1.9.2-p180@global:/Users/foo/.rvm/gems/ruby-1.9.2-p180:/Users/foo/.rvm/gems/rub

  3. ruby - 通过 RVM (OSX Mountain Lion) 安装 Ruby 2.0.0-p247 时遇到问题 - 2

    我的最终目标是安装当前版本的RubyonRails。我在OSXMountainLion上运行。到目前为止,这是我的过程:已安装的RVM$\curl-Lhttps://get.rvm.io|bash-sstable检查已知(我假设已批准)安装$rvmlistknown我看到当前的稳定版本可用[ruby-]2.0.0[-p247]输入命令安装$rvminstall2.0.0-p247注意:我也试过这些安装命令$rvminstallruby-2.0.0-p247$rvminstallruby=2.0.0-p247我很快就无处可去了。结果:$rvminstall2.0.0-p247Search

  4. ruby - Fast-stemmer 安装问题 - 2

    由于fast-stemmer的问题,我很难安装我想要的任何ruby​​gem。我把我得到的错误放在下面。Buildingnativeextensions.Thiscouldtakeawhile...ERROR:Errorinstallingfast-stemmer:ERROR:Failedtobuildgemnativeextension./System/Library/Frameworks/Ruby.framework/Versions/2.0/usr/bin/rubyextconf.rbcreatingMakefilemake"DESTDIR="cleanmake"DESTDIR=

  5. ruby - 安装 Ruby 时遇到问题(无法下载资源 "readline--patch") - 2

    当我尝试安装Ruby时遇到此错误。我试过查看this和this但无济于事➜~brewinstallrubyWarning:YouareusingOSX10.12.Wedonotprovidesupportforthispre-releaseversion.Youmayencounterbuildfailuresorotherbreakages.Pleasecreatepull-requestsinsteadoffilingissues.==>Installingdependenciesforruby:readline,libyaml,makedepend==>Installingrub

  6. ruby-on-rails - Ruby url 到 html 链接转换 - 2

    我正在使用Rails构建一个简单的聊天应用程序。当用户输入url时,我希望将其输出为html链接(即“url”)。我想知道在Ruby中是否有任何库或众所周知的方法可以做到这一点。如果没有,我有一些不错的正则表达式示例代码可以使用... 最佳答案 查看auto_linkRails提供的辅助方法。这会将所有URL和电子邮件地址变成可点击的链接(htmlanchor标记)。这是文档中的代码示例。auto_link("Gotohttp://www.rubyonrails.organdsayhellotodavid@loudthinking.

  7. java - 从 JRuby 调用 Java 类的问题 - 2

    我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www

  8. ruby-on-rails - 简单的 Ruby on Rails 问题——如何将评论附加到用户和文章? - 2

    我意识到这可能是一个非常基本的问题,但我现在已经花了几天时间回过头来解决这个问题,但出于某种原因,Google就是没有帮助我。(我认为部分问题在于我是一个初学者,我不知道该问什么......)我也看过O'Reilly的RubyCookbook和RailsAPI,但我仍然停留在这个问题上.我找到了一些关于多态关系的信息,但它似乎不是我需要的(尽管如果我错了请告诉我)。我正在尝试调整MichaelHartl'stutorial创建一个包含用户、文章和评论的博客应用程序(不使用脚手架)。我希望评论既属于用户又属于文章。我的主要问题是:我不知道如何将当前文章的ID放入评论Controller。

  9. ruby-on-rails - Prawn - 表格单元格内的链接 - 2

    我正在尝试用Prawn生成PDF。在我的PDF模板中,我有带单元格的表格。在其中一个单元格中,我有一个电子邮件地址:cell_email=pdf.make_cell(:content=>booking.user_email,:border_width=>0)我想让电子邮件链接到“mailto”链接。我知道我可以这样链接:pdf.formatted_text([{:text=>booking.user_email,:link=>"mailto:#{booking.user_email}"}])但是将这两行组合起来(将格式化文本作为内容)不起作用:cell_email=pdf.make_c

  10. 亚特兰蒂斯的回声(中文版): chatGPT 的杰作 - 2

    英文版英文链接关注公众号在“亚特兰蒂斯的回声”中踏上一段难忘的冒险之旅,深入未知的海洋深处。足智多谋的考古学家AriaSeaborne偶然发现了一件古代神器,揭示了一张通往失落之城亚特兰蒂斯的隐藏地图。在她神秘的导师内森·兰登教授的指导和勇敢的冒险家亚历克斯·默瑟的帮助下,阿丽亚开始了一段危险的旅程,以揭开这座传说中城市的真相。他们的冒险之旅带领他们穿越险恶的大海、神秘的岛屿和充满陷阱和谜语的致命迷宫。随着Aria潜在的魔法能力的觉醒,她被睿智勇敢的QueenNeria的幻象所指引,她让她为即将到来的挑战做好准备。三人组揭开亚特兰蒂斯令人惊叹的隐藏文明,并了解到邪恶的巫师马拉卡勋爵试图利用其古

随机推荐