我需要在 Oracle 中创建表时附加 SYSDATE。请让我知道是否有直接的方法(仅使用 SQL)或者我必须使用 PL/SQL。
例如,如果表名是 ABC,我需要将表创建为 ABC_20130416。
如果需要更多信息,请告诉我。
如果 SQL*Plus 始终可用,您可以使用变量来执行此操作,例如(未经测试):
SQL>col yyyymmdd for a8 new_value v
SQL>select to_char(sysdate, 'YYYYMMDD') as yyyymmdd from dual;
SQL>create table ABC_&v (col1 integer);
另一方面,如果您希望能够在任何地方执行此操作,您将需要 PL/SQL 和动态 SQL:
declare
l_tablename varchar2(30) := 'ABC_' || to_char(sysdate, 'YYYYMMDD')
begin
execute immediate 'create table ' || l_tablename || ' (col1 integer)';
end;
/
或者只是先正常创建表,然后重命名:
create table xyz (
... many columns ...
);
declare
l_tablename varchar2(30) := 'ABC_' || to_char(sysdate, 'YYYYMMDD')
begin
execute immediate 'rename xyz to ' || l_tablename;
end;
/
仅使用 PL/SQL:
begin
execute immediate 'create table foo_' || your_timestamp_here ;
end;
PL/SQL 代码:
declare
tabname varchar(32);
begin
tabname := 'abc'|| TO_CHAR(SYSDATE, 'YYYYMMDD');
execute immediate 'create table '|| tabname ||' ( f1 number, f2 number, f3 number)';
end;