>php教程 >php手册 >php+mysql设置编码格式

php+mysql设置编码格式

WBOY
WBOY원래의
2016-06-06 19:58:07979검색

当我们通过PHP存取MySQL数据库时,就算设置了表的默认字符集为utf8,并且通过UTF-8编码发送查询,你会发现存入数据库的仍然是乱码。问题就出在connection连接层上。解决方法是在发送查询前执行一下下面这句: 1. SET NAMES 'utf8'; 它相当于下面的三句指令:

  当我们通过PHP存取MySQL数据库时,就算设置了表的默认字符集为utf8,并且通过UTF-8编码发送查询,你会发现存入数据库的仍然是乱码。问题就出在connection连接层上。解决方法是在发送查询前执行一下下面这句:

1.  SET NAMES 'utf8';

它相当于下面的三句指令:
SET character_set_client = utf8;
SET character_set_results = utf8;
SET character_set_connection = utf8;

2. 创建数据库
mysql> create database name character set utf8;

3. 创建表
CREATE TABLE `type` (
`id` int(10) unsigned NOT NULL auto_increment,
`flag_deleted` enum('Y','N') character set utf8 NOT NULL default 'N',
`flag_type` int(5) NOT NULL default '0',
`type_name` varchar(50) character set utf8 NOT NULL default '',
PRIMARY KEY (`id`)
)  DEFAULT CHARSET=utf8;

4. 修改数据库成utf8的.
alter database name character set utf8;

5. 修改表默认用utf8.

alter table type character set utf8;

6. 修改字段用utf8.

alter table type modify type_name varchar(50) CHARACTER SET utf8;

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.