Incorrect character set and collation settings in MySQL can lead to data display issues, especially with non-English characters. This guide provides solutions for fixing these problems.
To change the character set and collation for an entire database, use this command:
<code class="language-sql">ALTER DATABASE <database_name> CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci;</code>
This updates the settings for all tables and columns within the database.
For a specific table, use this command:
<code class="language-sql">ALTER TABLE <table_name> CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci;</code>
This applies the new settings to all columns in the table.
To alter the collation of an individual column, use the MODIFY
clause:
<code class="language-sql">ALTER TABLE <table_name> MODIFY <column_name> VARCHAR(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci;</code>
The utf8mb4_0900_ai_ci
collation is composed of:
utf8mb4
: 4-byte UTF-8 encoding (supports a wider range of characters)._0900_
: Performance optimization for MySQL 9.0 and later._ai_ci
: Case-insensitive and accent-insensitive comparison.After these changes, characters previously displayed as "???" should now render correctly.
The above is the detailed content of How Can I Fix Incorrect Character Set and Collation in My MySQL Database?. For more information, please follow other related articles on the PHP Chinese website!