您好,欢迎访问一九零五行业门户网

php中的mysqli_set_charset和SET NAMES优劣分析

mysql, cs_name)) { //** 调用libmysql的对应函数 return_false; } return_true; }?>
复制代码
那mysql_set_character_set又做了什么呢?
options.charset_dir) charsets_dir= mysql->options.charset_dir; if (strlen(cs_name) (cs= get_charset_by_csname(cs_name, my_cs_primary, myf(0)))) { char buff[my_cs_name_size + 10]; charsets_dir= save_csdir; /* skip execution of set names for pre-4.1 servers */ if (mysql_get_server_version(mysql) return 0; sprintf(buff, set names %s, cs_name); if (!mysql_real_query(mysql, buff, strlen(buff))) { mysql->charset= cs; } } //以下省略?>
复制代码
我们可以看到, mysqli_set_charset除了做了”set names”以外, 还多做了一步:
charset= cs; }?>
复制代码
而对于mysql这个核心结构的成员charset又有什么作用呢?
这就要说说mysql_real_escape_string()了, 这个函数和mysql_escape_string的区别就是, 它会考虑”当前”字符集. 那么这个当前字符集从哪里来呢?
对了, 你猜的没错, 就是mysql->charset.
mysql_real_string在判断宽字符集的字符的时候, 就根据这个成员变量来分别采用不同的策略, 比如如果是utf-8, 那么就会采用libmysql/ctype-utf8.c.
看个实例, 默认mysql连接字符集是latin-1, (经典的5c问题):
复制代码
因为, “慭”的gbk编码低字节为5c, 也就是ascii中的”\”, 而因为除了mysql(i)_set_charset影响mysql->charset以外, 其他时刻mysql->charset都为默认值, 所以, 结果就是:$ php -f 5c.phpstring(3) 慭\string(3) 慭\string(3) 慭\string(2) 慭
本文转自:http://www.laruence.com/2010/04/12/1396.html
其它类似信息

推荐信息