主键自增长

a)         创建表

                         i.  有主键,主键自增长

                       ii.   有一个数值类型,数据不能为空

                      iii.   有一个字符串类型,内容随意

b)         写一个存储过程,插入10000条数据

c)         统计这张表的

                         i.  记录数

                       ii.  数据类型字段的平均值、最大值、最小值、汇总求和

           D)将c查询出来的记录,写入另外一张或多张表。


create table users
( id integer primary key,
  name varchar2(20),
  age integer
 );
 


CREATE SEQUENCE seq
 INCREMENT BY 1       -- 每次加几个  
     START WITH 1     -- 从1开始计数  
     NOMAXVALUE       -- 不设置最大值  
     NOCYCLE          -- 一直累加,不循环  
     NOCACHE;
     
CREATE or replace  TRIGGER trig BEFORE
insert ON  users FOR EACH ROW
begin
select seq.nextval into:New.id from dual;
end;   

--insert into users(name,age) values('zhangsan',20);
--select * from users;
--delete from users where id<=6 and id>=1;


create table huizong
(
       id integer primary key,
       v_avg integer,
       v_max integer,
       v_min integer,
       v_sum integer
);

CREATE SEQUENCE seq2
 INCREMENT BY 1       -- 每次加几个  
     START WITH 1     -- 从1开始计数  
     NOMAXVALUE       -- 不设置最大值  
     NOCYCLE          -- 一直累加,不循环  
     NOCACHE;
CREATE or replace  TRIGGER trig2 BEFORE
insert ON  huizong FOR EACH ROW
begin
select seq2.nextval into:New.id from dual;
end;   
create or replace procedure pro_01 is
  i           integer;
  num_of_rows integer; --保存数据条数
  avg_age     integer; --保存年龄平均值
  max_age     integer; --保存年龄最大值
  min_age     integer; --保存年龄最小值
  sum_age     integer; --保存年龄总和
begin
  for i in 1 .. 1000 LOOP
    insert into users (name, age) values ('zhangsan', mod(i, 50) + 10);
    commit;
  END LOOP;
  EXECUTE   IMMEDIATE 'TRUNCATE TABLE huizong';
  
  select count(*), avg(age), max(age), min(age), sum(age)
    into num_of_rows, avg_age, max_age, min_age, sum_age
    from users;
  insert into huizong
    (v_avg, v_max, v_min, v_sum)
  values
    (num_of_rows, max_age, min_age, sum_age);
  commit;

end;


begin
  pro_01;
end;
select * from users;



posted @ 2015-01-05 15:34  岳麓丹枫  阅读(152)  评论(0编辑  收藏  举报