sigleSchool 存储过程例1

CREATE OR REPLACE PROCEDURE SINGLSCHOOL
(
PICIID IN VARCHAR2
, SCHOOLID IN NUMBER
, SCHETYPE IN number
, SCHENAME OUT VARCHAR2
, ISCORE OUT VARCHAR2
, ISTHRE OUT VARCHAR2
, ISBASE OUT VARCHAR2
, ISONLINE OUT VARCHAR2
, TEACHTO OUT VARCHAR2
, CLASSCOUNT OUT VARCHAR2
, STHCOUNT OUT VARCHAR2
, SCHEID OUT VARCHAR2
) AS
--按照条件查询课程信息
SCHENAMETMP t_app_dic.f_dic_value%TYPE;
CORETMP t_app_dic.f_dic_value%TYPE;
THRETMP t_app_dic.f_dic_value%TYPE;
BASETMP t_app_dic.f_dic_value%TYPE;
ONLINETMP t_app_dic.f_dic_value%TYPE;
TEACHOTMP t_app_dic.f_dic_value%TYPE;
CLASCTMP NUMBER;
STUCTMP NUMBER;
SCHEIDTMP T_APP_SUB_SCHE.ID%TYPE;

cursor sches (SCHOOLID organization.id%type ,PICIID t_app_pici.id%type,SCHETYPE t_app_sub_sche.f_sche_type%type) is
select sche.f_sche_name,(select f_dic_value from t_app_dic where f_dic_num= sche.f_sche_core and f_dic_name=‘核心课程‘) ,
(select f_dic_value from t_app_dic where f_dic_num= sche.f_thre_prac and f_dic_name=‘理论/实践‘) ,
(select f_dic_value from t_app_dic where f_dic_num= sche.f_base_pro and f_dic_name=‘基础/专业‘) ,
(select f_dic_value from t_app_dic where f_dic_num= sche.F_ONLINE and f_dic_name=‘是否开网络课程‘) ,
(select f_dic_value from t_app_dic where f_dic_num= sche.F_TEACH_OBJE and f_dic_name=‘培养对象‘) ,
count(sc.f_class_id),sum(c.F_STU_COUNT),SCHE.ID
from t_app_sub_sche sche,t_app_sche_class sc,t_app_class c
where c.id(+)=sc.f_class_id and sche.id= sc.f_sche_id(+) and sche.f_validate = ‘0‘ and sche.f_subunit_code=(SCHOOLID||‘‘) and sche.f_subunit_pici_pre = PICIID and sche.f_sche_type=SCHETYPE
group by SCHE.ID,sche.f_sche_name,sche.f_sche_core, sche.f_base_pro, sche.F_ONLINE, sche.F_TEACH_OBJE,sche.f_thre_prac;
BEGIN

SCHENAME:=‘ ‘;
ISCORE:=‘ ‘;
ISTHRE:=‘ ‘;
ISBASE:=‘ ‘;
ISONLINE:=‘ ‘;
TEACHTO:=‘ ‘;
CLASSCOUNT:=‘ ‘;
STHCOUNT:=‘ ‘;
SCHEID:=‘ ‘;
open sches(SCHOOLID,PICIID,SCHETYPE);
LOOP
fetch sches into SCHENAMETMP,CORETMP,THRETMP, BASETMP , ONLINETMP,TEACHOTMP, CLASCTMP, STUCTMP,SCHEIDTMP;
exit when sches%notfound;
SCHENAME:=SCHENAME||SCHENAMETMP||‘ ,‘;
ISCORE:=ISCORE||CORETMP||‘ ,‘;
ISTHRE:=ISTHRE||THRETMP||‘ ,‘;
ISBASE:=ISBASE||BASETMP||‘ ,‘;
ISONLINE:=ISONLINE||ONLINETMP||‘ ,‘;
TEACHTO:=TEACHTO||TEACHOTMP||‘ ,‘;
CLASSCOUNT:=CLASSCOUNT||CLASCTMP||‘ ,‘;
STHCOUNT:=STHCOUNT||STUCTMP||‘ ,‘;
SCHEID:=SCHEID||SCHEIDTMP||‘ ,‘;
end loop;
close sches;
DBMS_OUTPUT.PUT_LINE(SCHENAME||‘::‘||ISCORE||‘::‘||ISTHRE||‘::‘||ISBASE||‘::‘||ISONLINE||‘::‘||CLASSCOUNT||‘::‘||STHCOUNT||‘::‘||TEACHTO);
END SINGLSCHOOL;

时间: 2024-10-04 01:34:57

sigleSchool 存储过程例1的相关文章

SQL语句(十八)—— 存储过程

存储过程 系统存储过程 自定义存储过程 扩展存储过程 一.创建存储过程 创建存储过程 --例1 USE SU GO Create Procedure SelProc AS Select * From SC GO --例2 USE SU GO Create Procedure CountProc AS Select Count(*) AS 总数 From Course Go 2. 存储过程调用 USE SU GO Exec SelProc Exec CountProc 3. 创建带输入参数的存储过

SQL课堂笔记--存储过程和触发器

---恢复内容开始--- 2017.11.21                  存储过程和触发器   1.存储过程的作用 当SQL server 创建应用程序时,可以用两种方法存储和执行程序: 1).将程序存储在本地,然后创建SQL server 发送命令并处理结果的应用程序  2).将程序以存储过程的形式存储在SQL Server服务器中,然后创建执行存储过程并处理结果的应用程序.SQL server推荐使用这种  2.存储过程(Store Procedure)是一组为了完成特定功能的T-S

Sql Server数据库设计高级查询

-------------------------------------第一章  数据库的设计------------------------------------- 软件开发周期:     (1)需求分析     (2)概要设计     (3)详细设计     (4)编码     (5)集成测试     (6)上线运行     (7)后期维护 1,数据库设计步骤:     (1)收集信息     (2)标识对象(确定数据库中有哪些表)     (3)标识对象的属性(确定每个表中的例)  

玩转mysql跟我一起装B,一起飞

存储函数:想调用者返回一个结果,这个结果可以用在表达式里,像(hex(),cast(),cos()这样的函数) 存储过程,使用call()语句调用,是一个独立的过程,不能用在函数里 存储过程使用情况总结: 1:实现某种动作效果无需返回一个值 2:运算返回多个值,函数做不到这一点 例存储函数: delimiter$$ create function f_a(ai_n int) returns varchar(64) begin declare vs_res varchar(64); declare

几例在ASP存储过程的使用方法

一.使用Command对象和Parameter对象传递参数 本讲将主要使用Microsoft SQL Server7.0数据库,先建立一个连接文件AdoSQL7.asp备用,以后用到时不再特别说明. <% 'AdoSQL7.asp Option Explicit Response.Expires = 0 '第一部分: 建立连接 Dim Cnn, StrCnn Set Cnn = Server.CreateObject("ADODB.Connection") StrCnn = &q

C#调用 Oracle 存储过程样例代码

-- 建表CREATE TABLE sale_report (     sale_date DATE NOT NULL ,     sale_item VARCHAR(2) NOT NULL ,      sale_money DECIMAL(10,2) NOT NULL,      PRIMARY KEY(sale_date, sale_item)); -- 測试数据DECLAREv_begin_day DATE;v_end_day DATE;BEGIN v_begin_day := TO_D

存储过程使用动态游标一例

数据表结构如下: SQL> desc record;Name        Type         Nullable Default Comments ----------- ------------ -------- ------- -------- RECORD_GUID VARCHAR2(50) Y                         DNIS        VARCHAR2(15) Y                         ANI         VARCHAR2

一个Sql Server 的游标与循环嵌套的存储过程用例

一个Sql Server 的游标与循环嵌套的存储过程用例 准备代码 --创建表 CREATE TABLE everyoneAVG ( ID int primary key identity(1,1), AccNo INT, AVGTime INT, AddTimes INT ); DROP TABLE everyoneAVG; SELECT ID,AccNo AS '用户号',AVGTime/60 AS '平均充值时间间隔(小时)',AddTimes AS '总充值次数' FROM everyo

java连接oracle数据库调用存储过程实现分页查询(emp为例)

第一步:建一个含游标类型的包 sql>create or replace package testPackage as type test_cursor is ref cursor;    --定义名为test_cursor 的游标 end testPackage; 第二步:编写分页的存储过程 sql>create or replace procedure fenYe( tableName in varchar2,--表名 pageSize in number,--每页显示的记录数 pageN