MySQL中文件排序中单双路排序

php中文网
发布: 2016-06-07 17:27:28
原创
1510人浏览过

在执行相关的SQL语句中,在mysql里进程容易出现一些file temp类似的字眼,该字眼告诉我们我们的宿主sql采用了文件排序等操作,这

在执行相关的sql语句中,在mysql里进程容易出现一些file temp类似的字眼,该字眼告诉我们我们的宿主sql采用了文件排序等操作,这可能会极大的影响我们的需要获取结果集的效率问题。

mysql中有2中文件排序算法:单路排序和双路排序;他们的区别于MYSQL中的max_length_for_sort_date具有相关性;单路算法的排序可以为排序中的每一行创建固定的缓冲区;如果库中出现超大字符串的时候,比如;BLOB,TEXT等可以采用前缀排序的算法,但是其值不能超过参数规定的值大小,在生产环境下,,建议采用更多的是单路的排序算法,他可以使磁盘的读写效率更高,sort_merge_passes的值会加大等!以下是相关innodb中给出的提示;

ut_ad(error == DB_SUCCESS);

 /* Commit the data dictionary transaction in order to release
 the table locks on the system tables.  This means that if
 MySQL crashes while creating a new primary key inside
 row_merge_build_indexes(), indexed_table will not be dropped
 by trx_rollback_active().  It will have to be recovered or
 dropped by the database administrator. */
 trx_commit_for_mysql(trx);

 row_mysql_unlock_data_dictionary(trx);
 dict_locked = FALSE;

 ut_a(trx->n_active_thrs == 0);
 ut_a(UT_LIST_GET_LEN(trx->signals) == 0);

 if (UNIV_UNLIKELY(new_primary)) {
  /* A primary key is to be built.  Acquire an exclusive
  table lock also on the table that is being created. */
  ut_ad(indexed_table != prebuilt->table);

  error = row_merge_lock_table(prebuilt->trx, indexed_table,
          LOCK_X);

  if (UNIV_UNLIKELY(error != DB_SUCCESS)) {

ReportPlus数据报表中心小程序
ReportPlus数据报表中心小程序

ReportPlust意在打造一套精美的数据报表模板,里面高度封装日历组件、表格组件、排行榜组件、条形进度条组件、文本块组件以及ucharts的多个图表组件,用户只需要按照虚拟数据的格式,传特定数据即可方便、快捷地打造出属于自己的报表页面。该小程序主要使用了ucharts和wyb-table两插件实现的数据报表功能。 特点使用的是uni-app中最受欢迎的图表uCharts插件完成图表展示,该插件

ReportPlus数据报表中心小程序 0
查看详情 ReportPlus数据报表中心小程序

   goto error_handling;
  }
 }

 /* Read the clustered index of the table and build indexes
based on this information using temporary files and merge sort. */
 error = row_merge_build_indexes(prebuilt->trx,
     prebuilt->table, indexed_table,
     index, num_of_idx, table); ----handler0alter.cc指定句柄操作过程中文件排序带来的merge的操作

  for (i = 0; i    row_merge_buf_t* buf = merge_buf[i];
   merge_file_t*  file = &files[i];
   const dict_index_t* index = buf->index;

   if (UNIV_LIKELY
      (row && row_merge_buf_add(buf, row, ext))) {
    file->n_rec++;
    continue;
   }

   /* The buffer must be sufficiently large
   to hold at least one record. */
   ut_ad(buf->n_tuples || !has_next);

   /* We have enough data tuples to form a block.
   Sort them and write to disk. */

   if (buf->n_tuples) {
    if (dict_index_is_unique(index)) {
     row_merge_dup_t dup;
     dup.index = buf->index;
     dup.table = table;
     dup.n_dup = 0;

     row_merge_buf_sort(buf, &dup);---row0merge.c文件中的,merge算法中排序的指定

linux

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号