MySQL中utf8_unicode_ci乱码的问题
存进去的全是问号,类似下面这样。
当时因为页面显示正常(全部使用utf8编码,语言是php,查询之前也有加编码设置),就没太在意!
这次更好服务器后,页面的输出就全部是问号了,不明白原因,求指教!
试过的方法有:
在查询之前设置
mysql_query("set names 'utf8'");
mysql_query("set character_set_client=utf8");
mysql_query("set character_set_results=utf8");
回复内容:
存进去的全是问号,类似下面这样。
当时因为页面显示正常(全部使用utf8编码,语言是php,查询之前也有加编码设置),就没太在意!
这次更好服务器后,页面的输出就全部是问号了,不明白原因,求指教!
试过的方法有:
在查询之前设置
mysql_query("set names 'utf8'");
mysql_query("set character_set_client=utf8");
mysql_query("set character_set_results=utf8");
你可以使用phpmyadmin看看是不是存进去的真的是乱码。
服务器编码,客户端编码,传输过程中编码保持一致。
有时候在命令行连接mysql,中文会乱码,原因是命令行对utf8不支持
补充:如果有phpmyadmin中看到是乱码,就是你程序和数据库设置的问题了:
修改php.ini
[client] default-character-set=utf8 [mysql] default-character-set=utf8 [mysqld] default-character-set=utf8
命令行连接mysql乱码
SET NAMES GB2312
从你描述的情况来看很可能是新服务器上数据库字符集设置问题。
mysql_query("set names 'utf8'")等同于:
set character_set_client=utf8;
set character_set_results=utf8;
set character_set_connection=utf8;
但是mysql在内部执行操作前会将连接字符集转换为内部操作字符集,顺序如下:
1.使用每个数据字段的CHARACTER SET设定值;
2.若上述值不存在,则使用对应数据表的DEFAULT CHARACTER SET设定值(MySQL扩展,非SQL标准);
3.若上述值不存在,则使用对应数据库的DEFAULT CHARACTER SET设定值;(character_set_database)
4.若上述值不存在,则使用character_set_server设定值。
所以你可以将database和server字符集设置为utf8试一下,
参考文章:http://www.laruence.com/2008/01/05/12...

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



MySQL is suitable for beginners because it is simple to install, powerful and easy to manage data. 1. Simple installation and configuration, suitable for a variety of operating systems. 2. Support basic operations such as creating databases and tables, inserting, querying, updating and deleting data. 3. Provide advanced functions such as JOIN operations and subqueries. 4. Performance can be improved through indexing, query optimization and table partitioning. 5. Support backup, recovery and security measures to ensure data security and consistency.

Navicat itself does not store the database password, and can only retrieve the encrypted password. Solution: 1. Check the password manager; 2. Check Navicat's "Remember Password" function; 3. Reset the database password; 4. Contact the database administrator.

Create a database using Navicat Premium: Connect to the database server and enter the connection parameters. Right-click on the server and select Create Database. Enter the name of the new database and the specified character set and collation. Connect to the new database and create the table in the Object Browser. Right-click on the table and select Insert Data to insert the data.

Navicat for MariaDB cannot view the database password directly because the password is stored in encrypted form. To ensure the database security, there are three ways to reset your password: reset your password through Navicat and set a complex password. View the configuration file (not recommended, high risk). Use system command line tools (not recommended, you need to be proficient in command line tools).

Common reasons why Navicat cannot connect to the database and its solutions: 1. Check the server's running status; 2. Check the connection information; 3. Adjust the firewall settings; 4. Configure remote access; 5. Troubleshoot network problems; 6. Check permissions; 7. Ensure version compatibility; 8. Troubleshoot other possibilities.

You can create a new MySQL connection in Navicat by following the steps: Open the application and select New Connection (Ctrl N). Select "MySQL" as the connection type. Enter the hostname/IP address, port, username, and password. (Optional) Configure advanced options. Save the connection and enter the connection name.

Common errors and solutions when connecting to databases: Username or password (Error 1045) Firewall blocks connection (Error 2003) Connection timeout (Error 10060) Unable to use socket connection (Error 1042) SSL connection error (Error 10055) Too many connection attempts result in the host being blocked (Error 1129) Database does not exist (Error 1049) No permission to connect to database (Error 1000)

To connect to a local MySQL database using Navicat: Create a connection and set the connection name, host, port, username, and password. Test the connection to make sure the parameters are correct. Save the connection. Select a new connection from the connection list. Double-click the database you want to connect to.
