Mysql表分区状态查询

Mysql表分区状态查询,第1张

一、查询mysql表是否为分区表:可以查看表具有哪几个分区、分区的方法、分区中数据的记录数等信息

SELECT PARTITION_NAME,PARTITION_METHOD,PARTITION_EXPRESSION,PARTITION_DESCRIPTION,TABLE_ROWS,SUBPARTITION_NAME,SUBPARTITION_METHOD,SUBPARTITION_EXPRESSION

FROM information_schema.PARTITIONS WHERE TABLE_SCHEMA=SCHEMA() AND TABLE_NAME='xw_coobill_order'

二、查询表有多少个分区

SELECT TABLE_NAME, COUNT(*) AS CNT

FROM information_schema.PARTITIONS WHERE PARTITION_NAME IS NOT NULL

GROUP BY TABLE_NAME ORDER BY CNT DESC LIMIT 50

三、分析执行语句

explain partitions select * from range_datetime where hiredate >= '20151207124503' and hiredate<='20151210111230'

四、分区管理

常规HASH和线性HASH的增加收缩分区的原理是一样的。增加和收缩分区后原来的数据会根据现有的分区数量重新分布。HASH分区不能删除分区,所以不能使用DROP PARTITION *** 作进行分区删除 *** 作;

只能通过ALTER TABLE ... COALESCE PARTITION num来合并分区,这里的num是减去的分区数量;

可以通过ALTER TABLE ... ADD PARTITION PARTITIONS num来增加分区,这里是null是在原先基础上再增加的分区数量。

如果查询当前用户下得分区表:\x0d\x0aselect * from user_tables where partitioned='YES'\x0d\x0a如果要查询整个数据库中的分区表:\x0d\x0aselect * from dba_tables where partitioned='YES' \x0d\x0a如果要查询某个用户下得分区表:\x0d\x0aselect * from dba_tables where partitioned='YES' and owner='ABCDEFG'\x0d\x0a 其中ABCDEFG为用户名

1、因为oracle运行在Linux系统下,首先,要连接Linux系统。

2、连上后,进行oracle控制台。输入命令: sqlplus  / as sysdba。

3、在oracle命令行中,输入: select t1.name,t2.name  from v$tablespace t1,v$datafile t2 where t1.ts# = t2.ts#。

4、这样就可以查看oracle数据库的表空间数据文件位置了。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10003861.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-04
下一篇 2023-05-04

发表评论

登录后才能评论

评论列表(0条)

保存