【Mysql 学习】 MERGE表方面的问题(二)
要重映射一个MERGE表到一个不同的MyISAM表集,你可以执行下列之一:
·DROP MERGE表并且重建它。
·使用ALTER TABLE tbl_name UNION=(...)来改变底层表的列表。
·改变.MRG文件,并对MERGE表或者所有底层表发出一个FLUSH TABLE语句来强制存储引擎去读新的定义文件。
MERGE表可以帮你解决以下问题:
·容易地管理一套日志表。比如,你可以把不同月的数据放进分离的表中,用myisampack压缩其中的一些,并随后创建一个MERGE表来把它们当作一个来使用。
·获得更快的速度。你可以以一些标准来分割大的只读表,然后放进不同磁盘上的单个表中。基于此的一个MERGE表可比使用大表要快得多。
·执行更有效的搜索。如果你确切知道要搜索什么,对一些查询你可以只在被分割的表的其中之一来搜索,并且对其它使用MERGE。你甚至有许多不同的MERGE表,它们使用有重叠的表套。
·执行更有效的修补。修补被映射到一个MERGE表中的单个表比修补单个大型表要更轻松。
·即刻映射许多表成一个。MERGE表不需要维护它自己的索引,因为它使用大哥表的所用。因此,MERGE表集合是非常块地创建或重映射。(注意,当你创建一个MERGE表之时,即使没有索引被创建,你必须仍然指定索引定义)。
·如果根据需要或按照批次,你有一组要合起来作为一个大表的表,你应该根据需要对它们创建一个MERGE表来替代大表。这样要快得多而且节约大量的磁盘空间。
·超过操作系统的文件尺寸限制。每个MyISAM表都受制于这个限制,但是一个MyISAM表的集合则不然。
·你可以通过定义一个映射到单个表的MERGE表来为一个MyISAM表创建一个别名或“同物异名”。这样做应该没有真实的可察觉的性能影响 (对每个读只有一些间接调用和memcpy()调用)。
MERGE表的缺点:
·只能对MERGE表使用仅相同的MyISAM表。
·不能在MERGE表中使用很多MyISAM功能。比如,不能在MERGE表上创建FULLTEXT索引。(可以在底层MERGE 表上创建FULLTEXT索引,但不能用全文搜索来搜索MERGE表)。
·如果MERGE表是非临时的,所有底层MyISAM表也必须是永久的。如果MERGE表是临时的,MyISAM表可以是任何临时&非临时的混合。
·MERGE表使用更多的文件描述符。如果是个客户端正使用一个映射到10个表的MERGE表,服务器使用(10*10)+10个文件描述符。(10个数据文件描述符给10个客户端每人一个,并且在客户端之间共享10个索引文件描述符)。
· 键读会更慢。当你读一个键的时候,MERGE存储引擎需要在所有 底层表上发出一个读以检查哪一个接近匹配给定的键。如果你随后做了一个read-next,MERGE存储引擎需要搜索读缓冲来找出下一个键。只有当一个键缓冲被耗尽,存储引擎才需要读下一个键块。这使得MERGE键在eq_ref搜索中非常慢,但在ref搜索中不是太慢。
下列是已知关于MERGE表的问题:
·如果你使用ALTER TABLE 来把MERGE表变为其它表类型,到底层表的映射就被丢失了。取而代之的,来自底层MyISAM表的行被复制到已更换的表中,该表随后被指定新类型。
·REPLACE不起作用。
·没有WHERE子句,或者在任何被映射到一个打开的MERGE表上的任何一个表上的REPAIR TABLE,TRUNCATE TABLE, OPTIMIZE TABLE或ANALYZE TABLE,你不能使用DROP TABLE, ALTER TABLE, DELETE FROM。如果你这么做了,MERGE表将仍旧指向原始表,这样产生意外结果。解决这个不足最简单的办法是在执行任何一个这些操作之前发出一个FLUSH TABLES语句来确保没有MERGE表仍旧保持打开。
·一个MERGE表不能在整个表上维持UNIQUE约束。当你执行一个INSERT, 数据进入第一个或者最后一个MyISAM表(取决于INSERT_METHOD选项的值)。MySQL确保唯一键值在那个MyISAM表里保持唯一,但不是跨集合里所有的表。
·当你创建一个MERGE表之时,没有检查去确保底层表的存在以及有相同的机构。当MERGE表被使用之时,MySQL检查每个被映射的表的记录长度是否相等,但这并不十分可靠。如果你从不相似的MyISAM表创建一个MERGE表,你非常有可能撞见奇怪的问题。
·在MERGE表中的索引的顺序和它的底层表中的索引应该一样。如果你使用ALTER TABLE给一个被用在MERGE表中的表添加一个UNIQUE索引,然后使用ALTER TABLE在MERGE表上添加一个非唯一索引,如果在底层表上已经有一个非唯一索引,对表的索引排序是不同的。(这是因为ALTER TABLE把UNIQUE索引放在非唯一索引之前以利于重复键的快速检测 )。因此对使用这样索引的表的查询可能返回不期望的结果。
·在Windows中,在一个被MERGE表使用的表上DROP TABLE不起作用,因为MERGE引擎的表映射对MySQL的更上层隐藏。因为Windows不允许已打开文件的删除,你首先必须刷新所有MERGE表(使用FLUSH TABLES)或在移除该表之前移除MERGE表。
Mysql数据库基础第八章:窗口函数和公用表表达式(CTE) # 1.窗口函数 MySQL从8.0版本开始支持窗口函数。窗口函数的作用类似于在查询中对数据进行分组,不同的是,分组操作会把分组的结果聚合成一条记录,而窗口函数是将结果置于每一条数据记录中。
相关文章
- 测试MySQL触发器构建:PHP测试实例(mysql触发器php)
- MySQL字段值替换实现方式(mysql字段替换)
- 学习MySQL数据库语法的基础知识(mysql数据库语法)
- 深入学习:PHP如何配置MySQL(php如何配置mysql)
- MySQL连接Java:一步一步实现连接(mysql连接java)
- C操作MySQL数据库:实现数据交互(c访问mysql)
- 学习MySQL:机会现在开启!(mysql如何学习)
- MySQL数据库管理:掌握牢固的基础知识(mysql数据库管理培训)
- 远程操作MySQL数据库:Android安全管理实践(安卓远程mysql数据库)
- MySQL表单备份及恢复(mysql表单)
- 掌握MySQL:成为学习中心的精英(mysql学习中心)
- MySQL数据库:行锁定的魔法(mysql数据库行锁)
- MySQL学习笔记:分位数统计方法(mysql分位数)
- MySQL的可靠性:强大且值得信赖(mysql可靠性)
- MySQL日志管理:学习掌握必备技能(mysql日志)
- MySQL视频教程:百度云上学习实践新技能(mysql视频教程百度云)
- 构建MySQL镜像网站:实现数据库一键部署(mysql 镜像网站)
- 如何在MySQL中切换用户登录?(mysql换用户登录)
- MySQL全面解析:从基础到高级,带你深入学习MySQL数据库技术(mysql大全)
- MySQL中long字段类型是什么(mysql中long么)
- 学习Mysql如何使用in操作符(mysql中in怎么使用)
- MySQL实现两表数值相减的简单方法(mysql两表数值相减)
- 学习MySQL 从初学者到高级开发者的必备PDF指南(mysql。pdf)
- MySQL表排序掌握两张表的技巧(mysql 两张表排序)
- MySQL 文件上传学习实践(mysql上传文件函数)
- MySQL学习之上传DLL命令详解(mysql上传dll命令)
- MySQL本机连接失败问题解决方法(mysql不能本机连接)
- MySQL分区建立失败的解决方法(mysql 不能建分区)