⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mysqlnd_statistics.c

📁 linux下安装不上mysql5与php5的可用此关联
💻 C
字号:
/*  +----------------------------------------------------------------------+  | PHP Version 6                                                        |  +----------------------------------------------------------------------+  | Copyright (c) 2006-2007 The PHP Group                                |  +----------------------------------------------------------------------+  | This source file is subject to version 3.01 of the PHP license,      |  | that is bundled with this package in the file LICENSE, and is        |  | available through the world-wide-web at the following url:           |  | http://www.php.net/license/3_01.txt                                  |  | If you did not receive a copy of the PHP license and are unable to   |  | obtain it through the world-wide-web, please send a note to          |  | license@php.net so we can mail you a copy immediately.               |  +----------------------------------------------------------------------+  | Authors: Georg Richter <georg@mysql.com>                             |  |          Andrey Hristov <andrey@mysql.com>                           |  |          Ulf Wendel <uwendel@mysql.com>                              |  +----------------------------------------------------------------------+*//* $Id: header,v 1.17 2006/01/01 13:09:48 sniper Exp $ */#include "php.h"#include "mysqlnd.h"#include "mysqlnd_priv.h"#include "mysqlnd_statistics.h"typedef struct st_mysqlnd_string{	char	*s;	size_t	l;} MYSQLND_STRING;#define STR_W_LEN(str)  str, (sizeof(str) - 1)/* {{{ mysqlnd_stats_values_names  */staticconst MYSQLND_STRING mysqlnd_stats_values_names[STAT_LAST] ={	{ STR_W_LEN("bytes_sent") },	{ STR_W_LEN("bytes_received") }, 	{ STR_W_LEN("packets_sent") },	{ STR_W_LEN("packets_received") },	{ STR_W_LEN("protocol_overhead_in") },	{ STR_W_LEN("protocol_overhead_out") },	{ STR_W_LEN("result_set_queries") },	{ STR_W_LEN("non_result_set_queries") },	{ STR_W_LEN("no_index_used") },	{ STR_W_LEN("bad_index_used") },	{ STR_W_LEN("buffered_sets") },	{ STR_W_LEN("unbuffered_sets") },	{ STR_W_LEN("ps_buffered_sets") },	{ STR_W_LEN("ps_unbuffered_sets") },	{ STR_W_LEN("flushed_normal_sets") },	{ STR_W_LEN("flushed_ps_sets") },	{ STR_W_LEN("rows_fetched_from_server") },	{ STR_W_LEN("rows_fetched_from_client") },	{ STR_W_LEN("rows_skipped") },	{ STR_W_LEN("copy_on_write_saved") },	{ STR_W_LEN("copy_on_write_performed") },	{ STR_W_LEN("command_buffer_too_small") },	{ STR_W_LEN("connect_success") },	{ STR_W_LEN("connect_failure") },	{ STR_W_LEN("connection_reused") },	{ STR_W_LEN("explicit_close") },	{ STR_W_LEN("implicit_close") },	{ STR_W_LEN("disconnect_close") },	{ STR_W_LEN("in_middle_of_command_close") },	{ STR_W_LEN("explicit_free_result") },	{ STR_W_LEN("implicit_free_result") },	{ STR_W_LEN("explicit_stmt_close") },	{ STR_W_LEN("implicit_stmt_close") },};/* }}} */static voidmysqlnd_fill_stats_hash(const MYSQLND_STATS * const stats, zval *return_value TSRMLS_DC ZEND_FILE_LINE_DC){	unsigned int i;	mysqlnd_array_init(return_value, STAT_LAST);	for (i = 0; i < STAT_LAST; i++) {		char tmp[22];				sprintf((char *)&tmp, MYSQLND_LLU_SPEC, stats->values[i]);#if PHP_MAJOR_VERSION >= 6		if (UG(unicode)) {			UChar *ustr, *tstr;			int ulen, tlen;			zend_string_to_unicode(UG(utf8_conv), &ustr, &ulen, mysqlnd_stats_values_names[i].s,									mysqlnd_stats_values_names[i].l + 1 TSRMLS_CC);			zend_string_to_unicode(UG(utf8_conv), &tstr, &tlen, tmp, strlen(tmp) + 1 TSRMLS_CC);			add_u_assoc_unicode_ex(return_value, IS_UNICODE, ZSTR(ustr), ulen, tstr, 1);			efree(ustr);			efree(tstr);		} else#endif				{				add_assoc_string_ex(return_value, mysqlnd_stats_values_names[i].s,								mysqlnd_stats_values_names[i].l + 1, tmp, 1);		}	}}/* {{{ _mysqlnd_get_client_stats */PHPAPI void _mysqlnd_get_client_stats(zval *return_value TSRMLS_DC ZEND_FILE_LINE_DC){	MYSQLND_STATS stats, *stats_ptr = mysqlnd_global_stats;	if (!stats_ptr) {		memset(&stats, 0, sizeof(stats));		stats_ptr = &stats;	}	mysqlnd_fill_stats_hash(stats_ptr, return_value TSRMLS_CC ZEND_FILE_LINE_CC);}/* {{{ _mysqlnd_get_connection_stats */void _mysqlnd_get_connection_stats(const MYSQLND * const conn, zval *return_value TSRMLS_DC ZEND_FILE_LINE_DC){	mysqlnd_fill_stats_hash(&(conn->stats), return_value TSRMLS_CC ZEND_FILE_LINE_CC);}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -