MySQL:如何编写Information Schema Plugin(11)

来源:未知 责任编辑:责任编辑 发表时间:2013-12-06 08:45 点击:

  

 const char *key; 

 size_t key_length; 

  

  

/*引用query_cache全局变量*/ 

  qc= (Accessible_Query_Cache *)&query_cache; 

  

/*对query_cache加锁*/ 

  query_cache.lock(); 

/*获取hash*/ 

 queries = qc->get_queries(); 

  

  /* 遍历hash中的所有记录/

  for(uint i= 0; i < queries->records; i++)

  {

         /*根据索引号获取记录*/ 

   query_cache_block_raw = hash_element(queries, i); 

   query_cache_block = (Query_cache_block*)query_cache_block_raw; 

query_cache_query= query_cache_block->query(); 

  

   table->field[COLUMN_STATEMENT_ID]->store(i+1, 0); 

  

   /* 获取sql语句*/ 

   statement_text = (const char*)query_cache_query->query(); 

   statement_text_length = strlen(statement_text); 

    

/*当超出长度时需要截断…*/ 

   table->field[COLUMN_STATEMENT_TEXT]->store(  (char*)statement_text 

                                ,statement_text_length > MAX_STATEMENT_TEXT_LENGTH? 

MAX_STATEMENT_TEXT_LENGTH 

                                :statement_text_length 

                                , scs 

   ); 

    

   /* 获取该查询的key*/ 

   key = (const char*)query_cache_query_get_key(  query_cache_block_raw                          

                                                           ,&key_length  , 0 ); 

    

key_length =strlen(key+statement_text_length+1)-1; 

    

         /*数据库名是key的一部分,适当的偏移key指针可以得到数据库名*/ 

发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
用户名: 验证码:点击我更换图片
最新评论 更多>>

推荐热点

  • mysql-mmm
  • mysqldump命令——MySQL数据库备份还原
  • Oracle数据导入MySQL的快捷工具:MySQL Migration Toolkit
  • 简简单单储存过程——循环一个select结果集
  • MySQL数据库十大优化技巧
  • Mysql安装笔记
  • Mysql主主复制架构配置
  • Mysql的Procedure 参数为NULL问题分析
  • MySQL Stmt预处理提高效率问题的小研究
网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
Copyright © 2008-2015 计算机技术学习交流网. 版权所有

豫ICP备11007008号-1