WEB开发网
开发学院WEB开发PHP 深入理解SET NAMES和mysql(i)_set_charset的区别 阅读

深入理解SET NAMES和mysql(i)_set_charset的区别

 2010-10-11 01:47:03 来源:WEB开发网   
核心提示:今天看到大家在讨论,发现这是个很严重而又容易疏忽的问题,深入理解SET NAMES和mysql(i)_set_charset的区别,我以前也一直是用set names,遂记录下来,也提醒自己一把,set names与mysql_set_charset有什么区别?一般情况下, 使用”SET NAMES&rdq

今天看到大家在讨论,发现这是个很严重而又容易疏忽的问题,我以前也一直是用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 342
PHP_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  下一页

Tags:SET NAMES mysql_set_charset mysqli_set_charset

编辑录入:coldstar [复制链接] [打 印]
    赞助商链接