数据库

 首页 > 数据库 > MySql > MySQL字符集:怎样才能保证不发生乱码

MySQL字符集:怎样才能保证不发生乱码

分享到:
【字体:
导读:
         摘要:MySQL字符集:怎样才能保证不发生乱码,阅读MySQL字符集:怎样才能保证不发生乱码,数据库中关于字符集的种类有很多,对编程有影响的主要是客户端字符集和数据库字符集(还有一个服务器字符集,不知道干什么用的)。 数据库中常用的操作就是保存数据和读取数据">

MySQL字符集:怎样才能保证不发生乱码

数据库中关于字符集的种类有很多,对编程有影响的主要是客户端字符集和数据库字符集(还有一个服务器字符集,不知道干什么用的)。


数据库中常用的操作就是保存数据和读取数据,在这过程中,乱不乱码和数据库字符集貌似没有什么关系。我们只要保证写入时选择的字符集和读取时选择的字符集一致,即只需保证两次操作的客户端字符集一致即可。


客户端字符集的设置,依据客户端不同方法不同:


1. 使用控制台连接,在my.ini文件中的client项里面设置;


2. 使用ems连接,优先使用ems连接配置的字符集,默认使用my.ini文件中的设置;


3. jdbc连接,在连接串中指定:


jdbc:mysql://192.168.3.99:3306/test?useUnicode=true& ;characterEncoding=gbk


在写入时Mysq会将客户端指定的字符集转换成数据库字符集存入数据文件,读取时又将数据库字符集转换成客户端指定的字符集展示给客户端,把客户端字符集和数据库字符设置一致,显而易见的好处是免掉转换的性能损耗;另外,如果考虑到以后数据库的迁移,将数据库字符集设置为大多数数据库都支持的字符集会省掉很大麻烦。


几个字符集相关的命令:


1. 查看 MySQL 数据库服务器字符集,数据库字符集和客户端字符集

show variables like '%char%';

character_set_client,客户端字符集

character_set_database,数据库字符集

character_set_server,服务器字符集

2. 查看 MySQL 数据表(table) 的字符集

show table status from tablename like '%countries%';

3. 查看 MySQL 数据列(column)的字符集。

show full columns from tablename;

4. 查看当前安装的 MySQL 所支持的字符集。

show char set;

MySQL字符集:怎样才能保证不发生乱码
分享到:
用MySQL实现SQL Server的sp_executesql
用MySQL实现SQL Server的sp_executesql从MySQL 5.0 开始,支持了一个全新的SQL句法: PREPARE stmt_name FROM preparable_stmt; EXECUTE stmt_name [USING @var_name [, @var_name] ...]; {DEALLOCATE | DROP} PREPARE stmt_name; 通过它,我们就可以实现类似 MS SQL 的 sp_executesql 执行动态SQL语句...
讲解一个经过高手优化的MySQL数据库实例
讲解一个经过高手优化的MySQL数据库实例据说这是高手优化的mysql,供大家参考,其中连接数: max_connections=1500可以根据服务器的性能更改. #set-variable = connect_timeout=5 #set-variable = wait_timeout=5 建议启用,负担重的服务器可以适当减少持续连接时间 [mysqld] basedir=D:/mysql #bind-address=ip datadir...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……