MySQL字符集:怎样才能保证不产生乱码
核心提示:数据库中关于字符集的种类有很多,对编程有影响的主要是客户端字符集和数据库字符集(还有1个服务器字符集,不知道干甚么用的)...
数据库中关于字符集的种类有很多,对编程有影响的主要是客户端字符集和数据库字符集(还有1个服务器字符集,不知道干甚么用的)。
数据库中常常使用的操纵就是保存数据和读取数据,在这进程中,乱稳定码和数据库字符集貌似没有甚么关系。我们只要保证写进时选择的字符集和读取时选择的字符集1致,即只需保证两次操纵的客户端字符集1致即可。
客户端字符集的设置,根据客户端不同方法不同:
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致,不言而喻的好处是免掉转换的性能消耗;另外,假设考虑到以后数据库的迁移,将数据库字符集设置为大多数数据库都支持的字符集会省掉很***烦。
几个字符集相干的命令:
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;
http://www.fw8.net/TAG:数据库,数据,服务器,客户端,字符集
评论加载中...
|