Chinaunix首页 | 论坛 | 博客
  • 博客访问: 569156
  • 博文数量: 126
  • 博客积分: 8010
  • 博客等级: 中将
  • 技术积分: 1112
  • 用 户 组: 普通用户
  • 注册时间: 2007-06-22 11:41
文章分类
文章存档

2010年(1)

2009年(5)

2008年(66)

2007年(54)

我的朋友

分类: Oracle

2008-02-28 13:48:01

 
1.Oracle中的table的列数最多有1000
create or replace procedure test_cols(cols number)
as
l_sql dbms_sql.varchar2s;
l_cursor number;
l_rows number;
begin
l_cursor := dbms_sql.open_cursor;
l_sql(1) :='create table cols'||cols||'(';
for i in 2..cols+1 loop
l_sql(i) := 'a' || to_char(i-1) || ' int,';
end loop;
l_sql(cols+1) := 'a' || to_char(cols) || ' int)';
dbms_sql.parse(c=>l_cursor,
statement=>l_sql,
lb=>l_sql.first,
ub=>l_sql.last,
lfflg=>TRUE,
language_flag=>dbms_sql.native);
dbms_sql.close_cursor(l_cursor);
end;
/
exec test_cols(1000);
2.
oracle的index最多可以包含多少个列呢?
普通index最多可以包含32个列
bitmap index最多可以包含30个列
create or replace procedure test_inds(cols number,tb_name varchar2,ix_type int default 0)
-- ix_type: 0 - btree index 1 - bitmap index
as
l_sql dbms_sql.varchar2s;
l_cursor number;
l_rows number;
begin
l_cursor := dbms_sql.open_cursor;
if ix_type = 0 then
l_sql(1) :='create index ix_'||cols||' on '|| tb_name || '(';
else
l_sql(1) :='create bitmap index ix_'||cols||' on '|| tb_name || '(';
end if;
for i in 2..cols+1 loop
l_sql(i) := 'a' || to_char(i-1) || ',';
end loop;
l_sql(cols+1) := 'a' || to_char(cols) || ')';
dbms_sql.parse(c=>l_cursor,
statement=>l_sql,
lb=>l_sql.first,
ub=>l_sql.last,
lfflg=>TRUE,
language_flag=>dbms_sql.native);
dbms_sql.close_cursor(l_cursor);
end;
/
exec test_inds(32,'COLS100');
阅读(2166) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~