今天看到大家在讨论,发现这是个很严重而又容易疏忽的问题,我以前也一直是用set names,遂记录下来,也提醒自己一把。
set names与mysql_set_charset有什么区别?
一般情况下, 使用”set names”就足够了, 也是可以保证正确的. 那么为什么手册又要说推荐使用 mysqli_set_charset(php>=5.0.5)呢。手册里面也没有明确说明。
首先, 很多人都不知道”set names”到底是做了什么,
我之前的文章《深入理解mysql字符集设置》中, 曾经介绍过character_set_client/character_set_connection/character_set_results这三个mysql的”环境变量”, 这里再简单介绍下,
这三个变量, 分别告诉mysql服务器, 客户端的编码集, 在传输给mysql服务器的时候的编码集, 以及期望mysql返回的结果的编码集.
比如, 通过使用”set names utf8″, 就告诉服务器, 我用的是utf-8编码, 我希望你也给我返回utf-8编码的查询结果.
一般情况下, 使用”set names”就足够了, 也是可以保证正确的. 那么为什么手册又要说推荐使用mysqli_set_charset(php>=5.0.5)呢?
首先, 我们看看mysqli_set_charset到底做了什么(注意星号注释处, mysql_set_charset类似):
//php-5.2.11-src/ext/mysqli/mysqli_nonapi.c line 342php_function(mysqli_set_charset){ my_mysql *mysql; zval *mysql_link; char *cs_name = null; unsigned int len; if (zend_parse_method_parameters(zend_num_args() tsrmls_cc, getthis() , os, &mysql_link, mysqli_link_class_entry, &cs_name, &len) == failure) { return; } mysqli_fetch_resource(mysql, my_mysql*, &mysql_link, mysqli_link , mysqli_status_valid); if (mysql_set_character_set(mysql->mysql, cs_name)) { //** 调用libmysql的对应函数 return_false; } return_true;}
1 2 下一页