首页 数据库 mysql教程 关于MySQL数据库乱码的问题总结

关于MySQL数据库乱码的问题总结

Jun 07, 2016 pm 05:41 PM
mysql 数据库

在数据库的操作中,我们经常会遇到乱码的问题,确实令人很心烦,虽然还没有完全弄明白其中的一些原理,但是有一些经验到是可以总结一下,指导一下后来者。一般我

    在数据库的操作中,我们经常会遇到乱码的问题,确实令人很心烦,虽然还没有完全弄明白其中的一些原理,但是有一些经验到是可以总结一下,指导一下后来者。

    一般我们在安排向导中最好设置数据库的统一编码方式为utf-8(当然,服务器空间,以后在自己的工程中做到处处统一为utf8),这样到是可以省去不少的麻烦。

    当mysql向导配置完成后,虚拟主机,进入数据库,执行 show variables like '%char%',网站空间,对应显示的结果应该都对应为utf-8

   但尽管如此,但我们利用command line client工具在表中插入中文的时候,会遇到data too long或者提示字符串Incorrect string value的问题,导致插入失败。

出现这个问题的原因是因为我们系统默认的编码方式为gbk(一般windows),所以对应的command line client接受的也是gbk的文本,但是mysql的connection的编码方式为utf8,而貌似mysql没有自动编码转化的功能,所以就出现不能识别的编码问题,导致插入失败。

解决方法就是在cmd下登陆command line client时使用:mysql -uroot -p --default-character-set=gbk; 这时在command line client下就能正常插入中文了。

同时在执行show variables like '%char%'语句时,出现了

这时发现对应几处的编码“暂时”(实际上,再次登陆后,查询时是没有变化的)改变了,这表示在这种方式进入的环境下,就可以与系统默认的编码吻合起来了,就可以正常地插入中文了。

对于不能插入的问题(当然包括在导入的操作),其中重点要关注和思考在两个方面上,一个是客户端面character_set_client和连接character_set_connection和返回的结果集character_set_results这其中涉及到与当前系统环境进行想到的环节,理解这其中的关系,或许就不会那么迷茫了。

还有,如果在一些mysql的图形化操作界面执行插入中文,则直接不会遇到这些问题,因为我们避免一个与系统有直接关系的输入client.

这是我在遇到这个问题的一点点思考,希望能给大家一些启发。

过去在不明白的时候,总是在网上找别人给的解决方案,总是在碰运气,最后即便是解决了问题,但还是不明白原理,并最终又在这上面出了问题,一句话说得好,有些东西不懂迟早还是要还的。所以我觉得,如果不是很非常关键,静下心来理理,把问题真正弄懂,才是最好的,也是最有成就感的。

本文出自 “花飞蝴蝶” 博客,请务必保留此出处

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1663
14
CakePHP 教程
1420
52
Laravel 教程
1313
25
PHP教程
1266
29
C# 教程
1239
24
laravel入门实例 laravel入门实例 Apr 18, 2025 pm 12:45 PM

Laravel 是一款 PHP 框架,用于轻松构建 Web 应用程序。它提供一系列强大的功能,包括:安装: 使用 Composer 全局安装 Laravel CLI,并在项目目录中创建应用程序。路由: 在 routes/web.php 中定义 URL 和处理函数之间的关系。视图: 在 resources/views 中创建视图以呈现应用程序的界面。数据库集成: 提供与 MySQL 等数据库的开箱即用集成,并使用迁移来创建和修改表。模型和控制器: 模型表示数据库实体,控制器处理 HTTP 请求。

MySQL和PhpMyAdmin:核心功能和功能 MySQL和PhpMyAdmin:核心功能和功能 Apr 22, 2025 am 12:12 AM

MySQL和phpMyAdmin是强大的数据库管理工具。1)MySQL用于创建数据库和表、执行DML和SQL查询。2)phpMyAdmin提供直观界面进行数据库管理、表结构管理、数据操作和用户权限管理。

MySQL与其他编程语言:一种比较 MySQL与其他编程语言:一种比较 Apr 19, 2025 am 12:22 AM

MySQL与其他编程语言相比,主要用于存储和管理数据,而其他语言如Python、Java、C 则用于逻辑处理和应用开发。 MySQL以其高性能、可扩展性和跨平台支持着称,适合数据管理需求,而其他语言在各自领域如数据分析、企业应用和系统编程中各有优势。

laravel框架安装方法 laravel框架安装方法 Apr 18, 2025 pm 12:54 PM

文章摘要:本文提供了详细分步说明,指导读者如何轻松安装 Laravel 框架。Laravel 是一个功能强大的 PHP 框架,它 упростил 和加快了 web 应用程序的开发过程。本教程涵盖了从系统要求到配置数据库和设置路由等各个方面的安装过程。通过遵循这些步骤,读者可以快速高效地为他们的 Laravel 项目打下坚实的基础。

甲骨文在商业世界中的作用 甲骨文在商业世界中的作用 Apr 23, 2025 am 12:01 AM

Oracle不仅是数据库公司,还是云计算和ERP系统的领导者。1.Oracle提供从数据库到云服务和ERP系统的全面解决方案。2.OracleCloud挑战AWS和Azure,提供IaaS、PaaS和SaaS服务。3.Oracle的ERP系统如E-BusinessSuite和FusionApplications帮助企业优化运营。

在MySQL中解释外键的目的。 在MySQL中解释外键的目的。 Apr 25, 2025 am 12:17 AM

在MySQL中,外键的作用是建立表与表之间的关系,确保数据的一致性和完整性。外键通过引用完整性检查和级联操作维护数据的有效性,使用时需注意性能优化和避免常见错误。

比较和对比Mysql和Mariadb。 比较和对比Mysql和Mariadb。 Apr 26, 2025 am 12:08 AM

MySQL和MariaDB的主要区别在于性能、功能和许可证:1.MySQL由Oracle开发,MariaDB是其分支。2.MariaDB在高负载环境中性能可能更好。3.MariaDB提供了更多的存储引擎和功能。4.MySQL采用双重许可证,MariaDB完全开源。选择时应考虑现有基础设施、性能需求、功能需求和许可证成本。

SQL与MySQL:澄清两者之间的关系 SQL与MySQL:澄清两者之间的关系 Apr 24, 2025 am 12:02 AM

SQL是一种用于管理关系数据库的标准语言,而MySQL是一个使用SQL的数据库管理系统。SQL定义了与数据库交互的方式,包括CRUD操作,而MySQL实现了SQL标准并提供了额外的功能,如存储过程和触发器。

See all articles