oracle 的存储过程

--建表  to  无参
create table test(A date); 
COMMIT;
insert into test values(sysdate);
commit;
select * from test order by A DESC;
-- 建表  to 有参 test01
create table test01(
       id Number(2) Not Null Primary Key,
       name varchar(20) not null,
       code varchar(20) not null,
       create_time date
);

-- 添加注释
comment on table test01 is '测试表01' ;
comment on column test01.id is '主键ID' ;
comment on column test01.name is '姓名' ;
comment on column test01.code is '代码' ;
comment on column test01.create_time is '创建时间' ;
-- 创建表  test02  02 没有设置触发器
create table test02(
       id Number(2) Not Null Primary Key,
       name varchar(20) not null,
       code varchar(20) not null,
       create_time date
);

-- 添加注释
comment on table test02 is '测试表01' ;
comment on column test02.id is '主键ID' ;
comment on column test02.name is '姓名' ;
comment on column test02.code is '代码' ;
comment on column test02.create_time is '创建时间' ;

-- 创建自增序列
create sequence test01Sequence Minvalue 1 Increment By 1 Start With 1;
create sequence test02Sequence Minvalue 1 Increment By 1 Start With 1;

-- 查询序列
select test02Sequence.Nextval from dual ;
-- 创建触发器
create trigger test01_seq before
       insert on test01 for each row when (new.id is null)
    begin
      select test01Sequence.Nextval into :new.id from dual;
    end ;
-- 插入数据 -- 新增时调用触发器给id赋值
 insert into test01 (name,code,create_time)values('李四','001',sysdate);
 commit ;    
-- 查询
select *from test01;
-- oracle 存储过程  package下
-- 1.创建包            
CREATE OR REPLACE PACKAGE UAT_DEMO IS
       PROCEDURE GET_TEST_ONE; --  创建无参的
       Procedure GET_TEST_TWO(name in varchar2, code in varchar2, create_time in date); -- 创建有参的
       Procedure GET_TEST_3(id in number, name in varchar2, code in varchar2, create_time in date); -- 创建有参的
END ;
-- 2.创建存储过程  没有返回值
create or replace package body UAT_DEMO is
   -- 插入数据到test
   PROCEDURE GET_TEST_ONE is
   begin 
     insert into TEST values(sysdate);
     commit;
   end GET_TEST_ONE;
   -- 插入数据到 test01 有触发器
   procedure  GET_TEST_TWO(name varchar2,code varchar2,create_time date) is
   begin
     insert into test01 (name,code,create_time)
     values(name, code ,create_time);
     commit ;  
   end GET_TEST_TWO;
   -- 插入数据到test02 无触发器
    procedure  GET_TEST_3( id number,name varchar2,code varchar2,create_time date) is
   begin
     insert into test02 (id ,name,code,create_time)
     values(test02Sequence.Nextval ,name, code ,create_time);
     commit ;  
   end GET_TEST_3;
end ;
-- 测试存储过程  并查询  -- 添加断点用于debug
-- 有参的手动输入参数
--说明 : 这里因为建立了触发器,所有不用输id, 若没有触发器,

-- 查询
select * from test;
select *from test01;
select *from test02;






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值