Mysql (三)Mysql 编码问题
admin
2023-05-16 02:22:05
0

处理mysql 编码问题

 

我们经常会遇到一些向MySQL数据库中插入中文,但是select出来的时候,却是乱码。

 

、查看库、表字符集命令

1.查看数据库支持的所有字符集

Show  character set (show char set)

Mysql (三)Mysql 编码问题

 

2.查看当前状态,里面当然包括字符集的设置

Status /s

Mysql (三)Mysql 编码问题

 

 

 

3.查看系统字符集设置,包括所有的字符集设置

Show  variables like  ‘%char%’;

Mysql (三)Mysql 编码问题

Mysql (三)Mysql 编码问题


4.查看数据表中字符集设置

Show  full columns  from  tablename ;

Mysql (三)Mysql 编码问题

也可以查看表结构

Show  create table  tablename\G;

Mysql (三)Mysql 编码问题

5.查看数据库编码(数据库结构)

Show  create database  dbname;//创建数据库指定的字符集

Mysql (三)Mysql 编码问题

 

二、创建库表列时要指定字符集(要统一)

1服务器级

在安装MySQL时可以设置服务器的默认编码格式,也可对my.ini做修改,修改[mysqld]里面的character_set_server=utf8,则可设置character_set_server的值。

2.数据库级

Create  database   dbname default  character  set utf8;

Mysql (三)Mysql 编码问题

注意,如果不指定默认的字符集,则系统会根据character_set_database的值进行设置

3.表级

Create  table dbname.tbname(id varchar(20) not null, name vharchar(20))engine=innoDB  default  charset=utf8;

Mysql (三)Mysql 编码问题

:定义表的默认字符集为utf8,即使character_set_databasegbk,但是表的列都为utf8。如果没有定义表的默认字符集,则他会按照character_set_database的值来设置

 

4.列级

Create  table db1.tb2(id  varchar(20)  not null, name  varchar(20)  character set utf8);

Mysql (三)Mysql 编码问题

注:如查没有指定列字符集、就使用表字符集、如查指定了就使用指定的。

图中:show  create table db1.tb2//是查看表结构

 

三、修改字符集

1.修改character_set_connectioncharacter_set_clientcharacter_set_results三值

对于一个连接来说、可以用

Set names  utf8来使用上面三个值改成utf8;

Mysql (三)Mysql 编码问题

Set name  ‘charset_name’; 相当于

Set character_set_client = charset_name;

SET character_set_results = charset_name; 

SET character_set_connection = charset_name;

 

2.修改character_set_database字段(也就是改数据库字符集)

Alter  database db_name  default  character set  charset_name;

 

Mysql (三)Mysql 编码问题

 

3.修改character_set_server字段

最简单的方法是直接改my.ini配置文件里面[mysqld]的字段,增加character-set-server=gbk,然后重启mysqld,则可改为你想要的字符集。

 

4.修改表的字符集

Alter  table tbname  default  character set  charsetname;

Alter  table tb1  default  character set  utf8

 

5.修改列的字符集

Alter  table tbname  modify  age varchar(30)  character  set utf8;

 

总结:

1、建库、建表、建字段设置统一编码。

2、PHP作为mysqle服务器客户端、连接编码set names utf8/gbk;

3、设置php返回给浏览器数据的编码。(Content-Type,header(),

<meta http-equiv="Content-Type"content="text/html; charset=gb2312" />

header("Content-type:text/html;charset=utf-8");

4、Php文件本身保存的编码(文件编码、通过文本编辑器设置)

5、安装mysql时设置好编码。(装好后可修改my.ini

 

 

微信扫一扫 、关注公众号

   不定时分享资料视频

Mysql (三)Mysql 编码问题

相关内容

热门资讯

签约!又一项目落户合肥 来源:合肥发布 日前 合肥市瑶海区与上海帆声图像科技有限公司 就帆声科技总部项目签约 据悉,帆声科技...
商务部:希望欧委会迅速纠正错误... 商务部新闻发言人就认定欧盟外国补贴调查相关做法构成不当域外管辖措施答记者问问:5月15日,司法部发布...
证达科技取得液晶显示屏用组装支... 国家知识产权局信息显示,证达科技(深圳)有限公司取得一项名为“液晶显示屏用组装支架”的专利,授权公告...
中国移动跟进Token经营 三... 转自:中国经营网 中经记者 谭伦 苏州报道 随着Token(词元)经营战略的密集落地,三大运营商在...
学校领导工作群发“亲密消息”,... 4月底,大皖新闻报道了吉林师范大学附属实验学校领导吴某在工作群发“亲密消息”一事,引发广泛关注。当地...
中国科学家重要发现,将改写教科... 顶夸克是最重的已知基本粒子,质量约为184倍氢原子核,寿命极短(约10-25秒)。传统理论认为其寿命...
一箭五星 中国成功发射泰景三号... 北京时间5月15日12时33分,我国在东风商业航天创新试验区使用力箭一号遥十三运载火箭,成功将泰景三...
第一批iPhone 17降价受... 5月15日消息,今日,国内电商苹果官方渠道突然降价,iPhone 17 Pro、iPhone 17 ...
原创 化... 在化学的奇妙世界里,每一滴溶液的变化都诉说着深刻的哲理。区区一百多种元素,通过不同的排列组合,竟构成...
吴宜泽否认“父母卖房供其打球”... 北京时间5月5日,2026斯诺克世锦赛决赛,中国小将吴宜泽以18比17夺得冠军,成为首位00后斯诺克...