N叉树的N能否可以人为修改?
mysql 页的大小16kb 通常来说改不了,如果你想让N尽量的多,有一个办法,就是让key尽量的小
目前而言page页能否修改? 16kb页
可以看到默认情况下mysql的页大小为16k,下面修改页面大小相关的源码
下面来做个测试,做测试的数据库版本为mysql-5.5.25:
下面修改页面大小相关的源码
vim /mysql-5.5.25/storage/innobase/include/univ.i
#define UNIV_PAGE_SIZE_SHIFT 14 ------------这个变量是修改为13
#define UNIV_PAGE_SIZE (1 << UNIV_PAGE_SIZE_SHIFT) --------这个变量就是Innodb页的大小,1左移13位刚好是8192。
修改完成后代码应该是:
#define UNIV_PAGE_SIZE_SHIFT 13
#define UNIV_PAGE_SIZE (1 << UNIV_PAGE_SIZE_SHIFT)
对于mysql 5.1的版本代码和5.5的修改方式稍微不同,下面的5.1版本代码的修改方式:
/* The universal page size of the database */
\#define UNIV_PAGE_SIZE (2 * 8192) /* NOTE! Currently, this has to be a ------修改为(2*4096)
power of 2 */
/* The 2-logarithm of UNIV_PAGE_SIZE: */
\#define UNIV_PAGE_SIZE_SHIFT 14 ------修改为13(该值是2的多少次方为UNIV_PAGE_SIZE)
/* Maximum number of parallel threads in a parallelized operation */
\#define UNIV_MAX_PARALLELISM 32
修改红色部分即可,记住UNIV_PAGE_SIZE大小只能是2的次方,如8K,16K,32k,UNIV_PAGE_SIZE_SHIFT 该值是2的多少次方为UNIV_PAGE_SIZE。
修改完成保存退出然后重新编译安装Mysql数据库,虚拟主机,过程就不写了。编译安装完成后再次查看页大小:
mysql>
mysql> SHOW GLOBAL STATUS like 'Innodb_page_size';
+------------------+-------+
| Variable_name | Value |
+------------------+-------+
| Innodb_page_size | 8192 |
+------------------+-------+
1 row in set (0.00 sec)
mysql>
可以看到页大小已经修改为8K。