--建表 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;
oracle 的存储过程
最新推荐文章于 2024-03-22 17:42:06 发布