可以在 oracle 中创建超过 2000 列的表。列名应该是任何东西,类型也应该是任何东西。我不知道怎么写
问问题
279 次
1 回答
15
不,这是不可能的。Oracle限制每个表有 1000 列。
但是,为什么您首先要创建一个包含 2000 列的表呢?这强烈暗示您的架构非常需要一些规范化。如果您能解释您要解决的业务问题,我们几乎可以肯定地提出更合适的解决方案。
如果您确实确定要违反适当的规范化并且想要在循环中生成列,您可以执行类似的操作
DECLARE
l_sql_stmt varchar2(1000);
BEGIN
l_sql_stmt := 'CREATE TABLE violation_of_normalization( col1 number )';
EXECUTE IMMEDIATE l_sql_stmt;
FOR i IN 2 .. 900
LOOP
l_sql_stmt := 'ALTER TABLE violation_of_normalization ADD( col' || i || ' number )';
EXECUTE IMMEDIATE l_sql_stmt;
END LOOP;
END;
做这样的事情是一个非常糟糕的主意,但它肯定是可能的。
于 2012-11-05T17:29:16.160 回答