在oracle中使用2000列创建表

时间:2012-11-05 17:27:08

标签: oracle

是否可以在oracle中创建超过2000列的表。列名应该是任何东西,类型也应该是任何东西。我不知道如何写

1 个答案:

答案 0 :(得分:15)

不,这是不可能的。 Oracle有一个limit of 1000 columns per table

为什么你想首先创建一个包含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;

做这样的事情是一个非常糟糕的主意,但这肯定是可能的。