Home >Backend Development >PHP Problem >Solve the problem of Chinese garbled characters in php mysql
php Mysql Chinese garbled solution: 1. Modify the encoding format in the database or table; 2. Add "mysqli_query("set names utf8");" to the PHP statement; 3. In the client Just add "header('charset=utf-8');".
Recommendation: "PHP Video Tutorial"
The problem of Chinese garbled characters in PHP and Mysql
When building a database with MySQL, sometimes there will be some garbled code problems. Here are some solutions.
Problem 1: The encoding format in the database or table is incorrect
When creating the database, use the following code to create it:
CREATE DATABASE `test` CHARACTER SET 'utf8' COLLATE 'utf8_general_ci';
When creating the table:
CREATE TABLE `table_name` ( id varchar(40) NOT NULL PRIMARY KEY AUTO_INCREMENT, `UserID` varchar(40) NOT NULL default '', ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
Once these three settings are set, Mysql will basically have no problems, that is, the same encoding format will be used when building databases and tables.
If the database has been created, you can use the following methods:
1. Check the default encoding format:
mysql> show variables like "%char%"; +--------------------------+---------------+ | Variable_name | Value | +--------------------------+---------------+ | character_set_client | gbk | character_set_connection | gbk | | character_set_database | utf8 | character_set_filesystem | binary | | character_set_results | gbk | | character_set_server | utf8 | | character_set_system | utf8 | +--------------------------+-------------+
Note: To determine the previous 2, you can use set names utf8 , set names gbk sets the default encoding format; you can set the database encoding more simply through workbench.
The effect of executing SET NAMES utf8 is equivalent to setting the following at the same time:
SET character_set_client='utf8'; SET character_set_connection='utf8'; SET character_set_results='utf8';
2. Check the encoding format of the test database:
mysql> show create database test; +------------+------------------------------------------------------------------------------------------------+ | Database | Create Database | +------------+------------------------------------------------------------------------------------------------+ | test | CREATE DATABASE `test` /*!40100 DEFAULT CHARACTER SET gbk */ | +------------+------------------------------------------------------------------------------------------------+
3. Check the encoding of the yjdb data table Format:
mysql> show create table yjdb; | yjdb | CREATE TABLE `yjdb` ( `sn` int(5) NOT NULL AUTO_INCREMENT, `type` varchar(10) NOT NULL, brc` varchar(6) NOT NULL, `teller` int(6) NOT NULL, `telname` varchar(10) NOT NULL, `date` int(10) NOT NULL, `count` int(6) NOT NULL, `back` int(10) NOT NULL, PRIMARY KEY (`sn`), UNIQUE KEY `sn` (`sn`), NIQUE KEY `sn_2` (`sn`) ) ENGINE=MyISAM AUTO_INCREMENT=1826 DEFAULT CHARSET=gbk ROW_FORMAT=DYNAMIC |
Problem 2: PHP and Mysql transfer encoding are incompatible
Need to add
mysqli_query(“set names utf8”);
mysql set names to the PHP statement to solve the cause of garbled characters:
http://blog.csdn.net/zsmj_2011/article/details/7943734
Question 3: Client decoding problem:
Add header('charset=utf-8'); that's it
The above is the detailed content of Solve the problem of Chinese garbled characters in php mysql. For more information, please follow other related articles on the PHP Chinese website!