热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

使用OraclePartitionTable对日志表进行分区

某个系统中有个日志型的表,现在的大小大概超过500MB,与该表相关的语句的执行计划都是对这个表进行全表扫描。下面是该表

某个系统中有个日志型的表,现在的大小大概超过500MB,与该表相关的语句的执行计划都是对这个表进行全表扫描。 下面是该表

  某个系统中有个日志型的表,现在的大小大概超过500MB,与该表相关的语句的执行计划都是对这个表进行全表扫描。

  下面是该表的定义:

  01 create table p_siteaccesslog

  02 (

  03 logID varchar(40) not null,

  04 infoType varchar(20) default 'site',

  05 siteId varchar(30),

  06 columnId varchar(30),

  07 infoId varchar(30),

  08 url varchar(300),

  09 location varchar(80),

  10 action varchar(20),

  11 accessDate varchar(10),

  12 accessTime varchar(8),

  13 sessionID varchar(90),

  14 userName varchar(30),

  15 userBrowser varchar(50),

  16 userOS varchar(30),

  17 userIp varchar(30),

  18 localization varchar(100),

  19 constraint PK_p_siteaccesslog primary key (logID)

  20 )

  该表有一个主键,为每条日志分配一个主键,感觉上一百年都不会用上这个主键来查一次数据。所以在新的分区表上将其去掉。

  1 test$ora8i@4.20 SQL> l

  2 1* select segment_name,sum(bytes/1048576) MB from user_extents group by segment_name order by 2 desc

  3 test$ora8i@4.20 SQL> /

  4

  5 SEGMENT_NAME MB

  6 ---------------------------------------- ----------

  7 P_SITEACCESSLOG 536

  由于是日志型的表,第一感觉就是按照时间分区,并淘汰(切换)旧的数据。

  于是沿着这个思路,,按照每月一个分区的策略构建分区表:

  01 create table my_p_siteaccesslog

  02 (

  03 logID varchar(40) not null,

  04 infoType varchar(20) default 'site',

  05 siteId varchar(30),

  06 columnId varchar(30),

  07 infoId varchar(30),

  08 url varchar(300),

  09 location varchar(80),

  10 action varchar(20),

  11 accessDate varchar(10),

  12 accessTime varchar(8),

  13 sessionID varchar(90),

  14 userName varchar(30),

  15 userBrowser varchar(50),

  16 userOS varchar(30),

  17 userIp varchar(30),

  18 localization varchar(100)

  19 )

  20 partition by range (accessDate)

  21 (

  22 partition pbf2009 values less than ('2009-01-01'),

  23 partition p200901 values less than ('2009-02-01'),

  24 partition p200902 values less than ('2009-03-01'),

  25 partition p200903 values less than ('2009-04-01'),

  26 partition p200904 values less than ('2009-05-01'),

  27 partition p200905 values less than ('2009-06-01'),

  28 partition p200906 values less than ('2009-07-01'),

  29 partition p200907 values less than ('2009-08-01'),

  30 partition p200908 values less than ('2009-09-01'),

  31 partition p200909 values less than ('2009-10-01'),

  32 partition p200910 values less than ('2009-11-01'),

  33 partition p200911 values less than ('2009-12-01'),

  34 partition p200912 values less than ('2010-01-01'),

  35 partition p201001 values less than ('2010-02-01'),

  36 partition p201002 values less than ('2010-03-01'),

  37 partition p201003 values less than ('2010-04-01'),

  38 partition p201004 values less than ('2010-05-01'),

  39 partition p201005 values less than ('2010-06-01'),

  40 partition p201006 values less than ('2010-07-01'),

  41 partition p201007 values less than ('2010-08-01'),

  42 partition p201008 values less than ('2010-09-01'),

  43 partition p201009 values less than ('2010-10-01'),

  44 partition p201010 values less than ('2010-11-01'),

  45 partition p201011 values less than ('2010-12-01'),

  46 partition p201012 values less than ('2011-01-01')

  47 )


推荐阅读
  • 本文由瀚高PG实验室撰写,详细介绍了如何在PostgreSQL中创建、管理和删除模式。文章涵盖了创建模式的基本命令、public模式的特性、权限设置以及通过角色对象简化操作的方法。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 本文探讨了在Oracle数据库中,动态SQL语句的执行及其对事务管理的影响,特别是关于回滚操作的有效性。重点讨论了一个具体场景:将预警短信从当前表迁移到历史表时遇到的字段长度不匹配问题及相应的异常处理。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • 本文详细介绍了Python编程语言的学习路径,涵盖基础语法、常用组件、开发工具、数据库管理、Web服务开发、大数据分析、人工智能、爬虫开发及办公自动化等多个方向。通过系统化的学习计划,帮助初学者快速掌握Python的核心技能。 ... [详细]
  • 作者:守望者1028链接:https:www.nowcoder.comdiscuss55353来源:牛客网面试高频题:校招过程中参考过牛客诸位大佬的面经,但是具体哪一块是参考谁的我 ... [详细]
  • 本文将深入探讨使用IMPDP工具进行分区表导入时需要注意的事项,涵盖最佳实践和常见问题。通过详细的分析与解释,帮助读者更好地理解和应用这些知识。 ... [详细]
  • PostgreSQL 10 离线安装指南
    本文详细介绍了如何在无法联网的服务器上进行 PostgreSQL 10 的离线安装,并涵盖了从下载安装包到配置远程访问的完整步骤。 ... [详细]
  • 探讨如何使用正则表达式从类 SQL 查询语句中提取字段及其对应的值。 ... [详细]
  • TCP长连接设备管理平台:架构与功能概览
    本文介绍了基于TCP长连接的设备管理平台的设计理念、技术选型及主要功能模块。最初,项目旨在实现简单的协议测试,但随着需求扩展,逐步演变为一个完整的前后端分离系统。 ... [详细]
  • Startup 类配置服务和应用的请求管道。Startup类ASP.NETCore应用使用 Startup 类,按照约定命名为 Startup。 Startup 类:可选择性地包括 ... [详细]
  • 使用Pandas高效读取SQL脚本中的数据
    本文详细介绍了如何利用Pandas直接读取和解析SQL脚本,提供了一种高效的数据处理方法。该方法适用于各种数据库导出的SQL脚本,并且能够显著提升数据导入的速度和效率。 ... [详细]
  • 本文介绍了如何在 Oracle 数据库中结合使用 UPDATE 和 SELECT 语句,以实现复杂的数据更新操作。首先准备测试环境和数据表,然后通过嵌套查询的方式从其他表中获取需要更新的值,最后执行更新操作并验证结果。 ... [详细]
  • 自己用过的一些比较有用的css3新属性【HTML】
    web前端|html教程自己用过的一些比较用的css3新属性web前端-html教程css3刚推出不久,虽然大多数的css3属性在很多流行的浏览器中不支持,但我个人觉得还是要尽量开 ... [详细]
  • MySQL DateTime 类型数据处理及.0 尾数去除方法
    本文介绍如何在 MySQL 中处理 DateTime 类型的数据,并解决获取数据时出现的.0尾数问题。同时,探讨了不同场景下的解决方案,确保数据格式的一致性和准确性。 ... [详细]
author-avatar
just路人周
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有