oracle⽤存储过程进⾏⾏转列(执⾏动态SQL语句)---------------------------------------------------------------建表
----------------判断student表是否存在
declare num number; --声明参数num  类型number
begin --开始
select count(1) into num from user_tables where table_name='student';
if num>0 then
execute immediate 'drop table student'; --动态sql 执⾏语句
end if;
end;
----------------建表
create table student
(
name varchar2(50),  --姓名
class varchar2(50),  --科⽬
score int  --分数
)
select * from student;
插⼊数据
----------------第⼀部分测试数据
insert into student(name,class,score)values('⼩明','语⽂',80);
insert into student(name,class,score)values('⼩明','英语',89);
insert into student(name,class,score)values('⼩明','数学',95);
insert into student(name,class,score)values('⼩强','数学',90);
insert into student(name,class,score)values('⼩强','英语',85);
insert into student(name,class,score)values('⼩强','语⽂',70);
COMMIT;
--select * from student;
创建⾏转列存储过程
思路:使⽤拼接字符串⽅式及⽤到⾏转列decode函数实现
---------------------------------------------------------------⾏转列的存储过程
oracle游标的使用CREATE OR REPLACE PROCEDURE P_STU  ---存储过程名称 P_STU  存储过程没有返回结果的
IS    ---声明变量
V_SQL VARCHAR2(2000);  --V_SQL  变量名  Varchar2 类型⽤于拼接SQL语句
CURSOR CLASS_CURSOR IS SELECT DISTINCT CLASS FROM student;
--游标循环使⽤游标声明 CURSOR  定义游标名称 CLASS_CURSOR 查询语句  SELECT DISTINCT CLASS FROM student;
--distinct 唯⼀值
--查询:class 通过 student表
BEGIN
V_SQL := 'SELECT name'; --初始值赋值 :=
--循环语句开始
FOR C IN CLASS_CURSOR  LOOP --循环参数 C  在游标⾥循环游标:CLASS_CURSOR
--拼接字符串⽤decode 函数  sum(decode(条件,参数,值1,值2)  ⾏转列条件满⾜(等于)参数返回值1 ,不满⾜(不等于)返回值2
V_SQL := V_SQL || ',' || 'SUM(DECODE(CLASS,''' || C.CLASS ||
''',score,0)) AS ' || C.CLASS;
END LOOP;
--结束循环
V_SQL := V_SQL || ' FROM student GROUP BY name';
--DBMS_OUTPUT.PUT_LINE(V_SQL);
V_SQL := 'CREATE OR REPLACE VIEW RESULT  AS '||  V_SQL; --创建视图
--DBMS_OUTPUT.PUT_LINE(V_SQL);
EXECUTE IMMEDIATE V_SQL; -- 执⾏动态sql 语句
END;
----------------------------------------------------------------结果
可以看到新增的存储过程p_stu
----------------执⾏存储过程,⽣成视图
BEGIN
P_STU;
END;
----------------结果
SELECT * FROM RESULT T;
----------------第⼆部分测试数据
insert into student(name,class,score)values('⼩明','化学',80);  insert into student(name,class,score)values('⼩强','化学',90);  COMMIT;
----------------报告存储过程,⽣成视图
BEGIN
P_STU;
END;
----------------结果
SELECT * FROM RESULT T;
--------------- 删除实体
DROP VIEW RESULT;
DROP PROCEDURE P_stu;
DROP TABLE student;
可能遇到的问题:
执⾏存储过程函数时创建不了 表⽰权限不⾜
需要对oracle 操作⽤户grant  创建 视图的权限 以及dba的权限假设⽤户A登陆操作数据库
grant create view to A;
grant  dba to A;
如果 ⾏列固定 可以直接⽤decode函数实现:

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。