Oracle 常用SQL笔记

1. 查询所有的分区表

SELECT * FROM DBA_TAB_PARTITIONS ;

2. 创建分区

alter table {TABLE_NAME} add  
partition SYS_P202403 values less than (TO_DATE('2024-03-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')),
partition SYS_P202404 values less than (TO_DATE('2024-04-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')),
partition SYS_P202405 values less than (TO_DATE('2024-05-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')),
partition SYS_P202406 values less than (TO_DATE('2024-06-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')),
partition SYS_P202407 values less than (TO_DATE('2024-07-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')),
partition SYS_P202408 values less than (TO_DATE('2024-08-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')),
partition SYS_P202409 values less than (TO_DATE('2024-09-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')),
partition SYS_P202410 values less than (TO_DATE('2024-10-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')),
partition SYS_P202411 values less than (TO_DATE('2024-11-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')),
partition SYS_P202412 values less than (TO_DATE('2024-12-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN'));

3.  日期比较大小和字符串比较大小哪个速度比较快

日期类型的比较: Oracle数据库中的日期数据类型是专门为存储和操作日期和时间设计的,数据库内部对日期进行优化存储和处理,因此当比较两个日期字段时,数据库可以直接对比它们对应的内部表示(通常是数值),这个过程非常快速且高效。
字符串类型的比较: 如果你将日期以字符串形式存储,并需要进行比较,数据库首先需要将字符串转换为日期格式,然后再进行比较。这个转换过程相对而言较为复杂,涉及到字符解析、格式匹配以及转换运算,性能上不如直接比较日期字段那么高效。
所以,在Oracle数据库中,比较日期字段的大小比比较同等含义的字符串表达的日期大小更快。最佳实践是尽量使用数据库原生的数据类型进行比较,避免不必要的类型转换操作。

 

posted @ 2024-04-01 10:07  大稳·杨  阅读(14)  评论(0编辑  收藏  举报