Home Backend Development PHP Problem How to solve Chinese garbled query in MySQL database with PHP?

How to solve Chinese garbled query in MySQL database with PHP?

Jul 22, 2020 am 10:50 AM
php

How to solve Chinese garbled query in MySQL database with PHP?

#How does PHP solve Chinese garbled characters when querying MySQL database?

1. The default encoding of the MySQL database is UTF-8;

2. When creating a table in MySQL, set the character set to UTF-8;

3. Before querying data in PHP, set the database encoding to UTF-8.

MySQL "SET NAMES x" character set problem analysis

I recently received training from BBT to build a voting system. The system code is not difficult, but my time was mainly spent studying character sets and encodings. The encoding (character set) issues of the MySQL and Apache systems made me rack my brains and suffer a lot. The solutions to these problems on the Internet are scattered and one-sided. Most of them provide solutions without explaining why. So I will summarize what I have gained in the past few days to avoid latecomers from taking detours again. This article is a little helpful for PHP writing (after reading it, you will know how to make your PHP program display normally on the servers of most space providers), but more help lies in the establishment and settings of the network server.

Let’s talk about MySQL’s character set first. Under Windows, you can change the default character set of the database by modifying the two fields

# CLIENT SECTION
[mysql]
default-character-set=utf8
# SERVER SECTION
[mysqld]
default-character-set=utf8
Copy after login

in my.ini. The first is the client's default character set, and the second is the server's default character set. Suppose we set both to utf8, and then enter "show variebles like "character_set_%";" in the MySQL Command Line Client. You can see the following characters:

character_set_client latin1
character_set_connection latin1
character_set_database utf8
character_set_results latin1
character_set_server utf8
character_set_system utf8
Copy after login

The utf8 follows our above Change the setting. At this time, if we read data from the database through a PHP program using UTF-8, it is likely to be a string of "?????" or other garbled characters. After searching online for a long time, the solution is simple. After connecting to the database, before reading the data, first execute a query "SET NAMES UTF8", that is,

mysql_query("SET NAMES UTF8");
Copy after login

in PHP, and the display will be normal (as long as the database The characters in the information are normal). Why is this happening? What exactly does the query "SET NAMES UTF8" do?

Go to the MySQL command line and enter "SET NAMES UTF8;", then execute "show variebles like "character_set_%";" and find that the variables "character_set_client", "character_set_connection" and "character_set_results" that were originally latin1 All the values ​​have changed to utf8. It turns out that these three variables are causing trouble. Consult the manual, the above sentence is equal to:

SET character_set_client = utf8;
SET character_set_results = utf8;
SET character_set_connection = utf8;
Copy after login

Look at the functions of these three variables:

Information input path: client→connection→server;

Information output path: server→connection→results.

In other words, each path needs to change the character set encoding 3 times. Take the garbled output as an example. For the utf8 data in the server, the incoming connection is converted to latin1, the incoming results are converted to latin1, and the utf-8 page converts the results again. If the two character sets are incompatible, such as latin1 and utf8, the conversion process is irreversible and destructive. So it can't be turned back.

But it should be stated here that the effect of "SET NAMES UTF8" is only temporary, and MySQL will return to the default after restarting.

Next, let’s talk about the configuration of MySQL on the server. Don't we have to add "SET NAMES UTF8" every time we read and write to the database to ensure that the encoding of data transmission is consistent? Can I configure MySQL so that those three variables default to the character set we want? The manual doesn't say it, and I couldn't find the answer online. Therefore, from a server configuration perspective, there is no way to omit that line of code.

Recommended tutorials: "PHP" "MySQL Tutorial"

The above is the detailed content of How to solve Chinese garbled query in MySQL database with PHP?. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Roblox: Bubble Gum Simulator Infinity - How To Get And Use Royal Keys
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Fusion System, Explained
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers Of The Witch Tree - How To Unlock The Grappling Hook
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Hot Topics

Java Tutorial
1665
14
PHP Tutorial
1269
29
C# Tutorial
1249
24
PHP and Python: Comparing Two Popular Programming Languages PHP and Python: Comparing Two Popular Programming Languages Apr 14, 2025 am 12:13 AM

PHP and Python each have their own advantages, and choose according to project requirements. 1.PHP is suitable for web development, especially for rapid development and maintenance of websites. 2. Python is suitable for data science, machine learning and artificial intelligence, with concise syntax and suitable for beginners.

PHP in Action: Real-World Examples and Applications PHP in Action: Real-World Examples and Applications Apr 14, 2025 am 12:19 AM

PHP is widely used in e-commerce, content management systems and API development. 1) E-commerce: used for shopping cart function and payment processing. 2) Content management system: used for dynamic content generation and user management. 3) API development: used for RESTful API development and API security. Through performance optimization and best practices, the efficiency and maintainability of PHP applications are improved.

PHP: A Key Language for Web Development PHP: A Key Language for Web Development Apr 13, 2025 am 12:08 AM

PHP is a scripting language widely used on the server side, especially suitable for web development. 1.PHP can embed HTML, process HTTP requests and responses, and supports a variety of databases. 2.PHP is used to generate dynamic web content, process form data, access databases, etc., with strong community support and open source resources. 3. PHP is an interpreted language, and the execution process includes lexical analysis, grammatical analysis, compilation and execution. 4.PHP can be combined with MySQL for advanced applications such as user registration systems. 5. When debugging PHP, you can use functions such as error_reporting() and var_dump(). 6. Optimize PHP code to use caching mechanisms, optimize database queries and use built-in functions. 7

The Enduring Relevance of PHP: Is It Still Alive? The Enduring Relevance of PHP: Is It Still Alive? Apr 14, 2025 am 12:12 AM

PHP is still dynamic and still occupies an important position in the field of modern programming. 1) PHP's simplicity and powerful community support make it widely used in web development; 2) Its flexibility and stability make it outstanding in handling web forms, database operations and file processing; 3) PHP is constantly evolving and optimizing, suitable for beginners and experienced developers.

PHP vs. Python: Understanding the Differences PHP vs. Python: Understanding the Differences Apr 11, 2025 am 12:15 AM

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHP is suitable for web development, with simple syntax and high execution efficiency. 2. Python is suitable for data science and machine learning, with concise syntax and rich libraries.

PHP and Python: Code Examples and Comparison PHP and Python: Code Examples and Comparison Apr 15, 2025 am 12:07 AM

PHP and Python have their own advantages and disadvantages, and the choice depends on project needs and personal preferences. 1.PHP is suitable for rapid development and maintenance of large-scale web applications. 2. Python dominates the field of data science and machine learning.

PHP vs. Other Languages: A Comparison PHP vs. Other Languages: A Comparison Apr 13, 2025 am 12:19 AM

PHP is suitable for web development, especially in rapid development and processing dynamic content, but is not good at data science and enterprise-level applications. Compared with Python, PHP has more advantages in web development, but is not as good as Python in the field of data science; compared with Java, PHP performs worse in enterprise-level applications, but is more flexible in web development; compared with JavaScript, PHP is more concise in back-end development, but is not as good as JavaScript in front-end development.

PHP and Python: Different Paradigms Explained PHP and Python: Different Paradigms Explained Apr 18, 2025 am 12:26 AM

PHP is mainly procedural programming, but also supports object-oriented programming (OOP); Python supports a variety of paradigms, including OOP, functional and procedural programming. PHP is suitable for web development, and Python is suitable for a variety of applications such as data analysis and machine learning.

See all articles