8 MySQL和字符集
当我将所有内容设置为UTF-8时,有人能解释我吗?我一直在收到那些该死的
  MySQL的 
  服务器版本:5.1.44 
  MySQL字符集:UTF-8 Unicode(utf8) 
我创建了一个新的数据库
  名称:utf8test 
  整理:utf8_general_ci 
  MySQL连接整理:utf8_general_ci 
我的SQL看起来像这样:
SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";
CREATE TABLE IF NOT EXISTS `test_table` (
    `test_id` int(11) NOT NULL,
    `test_text` text NOT NULL,
    PRIMARY KEY (`test_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
INSERT INTO `test_table` (`test_id`, `test_text`) VALUES
(1, 'hééélo'),
(2, 'wööörld');
我的PHP / HTML:
<?php
$db_conn = mysql_connect("localhost", "root", "") or die("Can't connect to db");
mysql_select_db("utf8test", $db_conn)  or die("Can't select db");
// $result = mysql_query("set names 'utf8'"); // this works... why??
$query = "SELECT * FROM test_table";        
$result = mysql_query($query);
$output = "";
while($row = mysql_fetch_assoc($result)) {
    $output .= "id: " . $row['test_id'] . " - text: " . $row['test_text'] . "<br />";
}
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html lang="it" xmlns="http://www.w3.org/1999/xhtml" xml:lang="it">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>UTF-8 test</title>
</head>
<body>
<?php echo $output; ?>
</body>
</html>
我将所有内容都设置为UTF-8
  不完全的。 
  你必须告诉mysql你的客户端的编码。 
  事实上,你不必在utf-8中设置“所有”。  你可以将你的表格设置为latin1并以utf-8格式输出。  或者相反。 
  非常灵活。 
  但是你必须明确地设置客户端的编码。  所以,这就是为什么它使用set names utf8 。  因为这个查询设置了客户端的编码。  让Mysql知道数据必须以utf-8发送。  非常明智,呵呵? 
另外我不得不提到你的SQL转储。 它需要相同的设置。 只是在顶部的某处设置名称。 因为你也从一些客户端发送这些查询。 此客户端的编码也需要设置。
还有一件事要提到:确保您的服务器在Content-type标头中发送适当的编码。 你也没有将它设置为UTF-8。
尝试在mysql_connect函数之后设置charachter编码,如下所示: 
 mysql_query ("set character_set_client='utf8'"); 
 mysql_query ("set character_set_results='utf8'"); 
 mysql_query ("set collation_connection='utf8_general_ci'");
  我没有看到"SET NAMES 'utf8';"  连接到数据库后立即查询。 
试试吧,可能适合你。
链接地址: http://www.djcxy.com/p/95199.html上一篇: 8 MySQL and Charset
下一篇: What special characters must be escaped in regular expressions?
