gpt4 book ai didi

database - 了解 Oracle 中的系统命名约定

转载 作者:搜寻专家 更新时间:2023-10-30 23:33:02 48 4
gpt4 key购买 nike

documentation 中所述Oracle 系统使用以 SYS_ORA_ 开头的名称:

Oracle uses system-generated names beginning with SYS_ for implicitly generated schema objects and subobjects, and names beginning with ORA_ for some Oracle-supplied objects. Oracle discourages you from using these prefixes in the names you explicitly provide to your schema objects and subobjects to avoid possible conflict in name resolution.

我目前正在使用具有分区名称的间隔分区表:

SYS_P2672
SYS_P1787
SYS_P654

分区名SYS_2627中的整数有没有约定strong> 正在生成?特别是,假设我的分区按月或周间隔生成,我想预测 future 的分区名称。

最佳答案

使用分区扩展名称和数据字典,而不是依赖系统名称。

分区扩展名称语法允许 SQL 语句根据分区内的值而不是实际的分区名称来引用分区。

语法:

enter image description here

(也有类似的SUBPARTITION版本。)

示例:

--Create and populate sample schema.
--drop table test1;

create table test1(a date)
partition by range(a)
interval (numToDSInterval(1, 'DAY'))
(
partition p1 values less than (date '2000-01-01')
);

insert into test1
select date '2000-01-01' + level
from dual
connect by level <= 100;

--Select the partition using a value.
select * from test1 partition for (date '2000-01-05');

如果这不起作用,可以通过数据字典检索分区信息。这变得很棘手,尤其是因为 HIGH_VALUE 作为文本存储在 LONG 列中。但在 PL/SQL 中使用时,它确实允许完全控制和自动化。

--Must create as a table to convert LONG to CLOB in SQL.
--(This would be easier in PL/SQL, you can just "TO_CHAR" it.)
create table temp_convert_long_to_lob as
select table_name, partition_name, to_lob(high_value) high_value
from user_tab_partitions
where table_name = 'TEST1';

--Show some data about the partitions.
select table_name, partition_name, to_char(high_value) high_value
from temp_convert_long_to_lob
order by partition_name;

TABLE_NAME PARTITION_NAME HIGH_VALUE
---------- -------------- ----------
TEST1 P1 TO_DATE(' 2000-01-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')
TEST1 SYS_P3094 TO_DATE(' 2000-01-03 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')
TEST1 SYS_P3095 TO_DATE(' 2000-01-04 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')
TEST1 SYS_P3096 TO_DATE(' 2000-01-05 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')

关于database - 了解 Oracle 中的系统命名约定,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46529418/

48 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com