create table mytest(name varchar(20),password varchar(30));





create or replace procedure sp_pro2 is 

begin 

insert into mytest values('fc','123');

end;









查看错误信息





show error





怎样调用该过程:





1。 exec 过程名 (參数,。。)

2.  call 过程名 (參数  )









set server output on





begin 

dbms_output.put_line('helloe');

end;





---------------------









declare 

  v_ename varchar(20);

begin 

    select ename into v_ename from emp where empno=&aa;

  dbms_output.put_line('姓名:'||v_ename);

  end;













  -----------

  create procedure sp_pro3 (spName varchar2,newSal number) is

  begin  

                          --运行部分

     update emp set sal=newSal where ename=spName;

     end;

     --dioyong 

     call sp_pro3('scott','8000');

 --------------函数 -------

 

    CREATE or replace  function sp_fun1(spName varchar2) return 

    number is yearsal number(7,2);

     begin select sal*12+nvl(comm,0) into yearsal from emp 

       where ename=spName;

       return yearsal;

       end;

    

    --diaoyong

    var abc number;

    call sp_fun1('SCOTT') into : abc;

    ---------------------------

    

   -------包------------由包规范和包体组成的

   --创建一个包sap_pack1 

   --声明该包有一个过程和一个函数

   create or replace package sp_pack1 is

     procedure update_sal(spName varchar2,newsal number);

     function  annual_income(spName varchar2) return number;

     end;

     

     --创建包体---

         create or replace package body sp_pack1 is

          

         procedure update_sal(spName varchar2,newsal number) is

     begin  

     update emp set sal=newsal where ename=spName;

     end;

     

      function   annual_income(spName varchar2) return number

           is yearsal number(7,2);

     begin   select sal*12+nvl(comm,0) into yearsal from emp 

       where ename=spName;

       return yearsal;

    end;

    end;





 ---调用 ----

        call sp_pack1.update_sal('SCOTT',9000);





















----------定义并使用变量---================================

     --  标量类型 scalar 

      v_ename varchar(10);

      v_sal  number(6,2):=5.4

      v_data date;

      v_valid  boolean not null default false;

                       ---输入员工号。显示 name sal tax

                       declare 

                         v_tax_rate number (3,2):=0.03;

                       -- v_ename varchar2(5);

                         v_ename  emp.ename%type;

                        -- v_sal  number(7,2);

                         v_sal  emp.sal%type;

                          v_tax_sal number (7,2);

                       begin  

                           select ename,sal into v_ename,v_sal from emp where empno=&no;

                           --计算所得税 

                             v_tax_sal:=v_sal*v_tax_rate;

                           --输出

                            dbms_output.put_line('name:'||v_ename||'工资'||v_sal  ||'交税:'||v_tax_sal);

                           end;





--复合类型  composite

      ----pl/sql 记录  类似于高级语言的结构体 

              --定义一个plsql 记录类型  emp_record_type

                  declare

                type   emp_record_type is record (aname emp.ename%type,salary emp.sal%type,title emp.job%type);

                --定义了一个 变量 sp_record  这个变量的类型是emp_record_type                                                                           

                  sp_record emp_record_type;

               begin 

                 select ename,sal,job into  sp_record from  emp where empno=7788;

               dbms_output.put_line('员工名:'||sp_record.aname);

               end;

      --------pl/sql  表  相当于该机语言里的数组 

            --定义一个plsql 表类型  emp_table_type   

                  declare 

                  type emp_table_type is table  of emp.ename%type index by  binary_integer;

                    sp_table emp_table_type;

                  begin 

                     select ename into  sp_table(0)  from emp where empno=7788;

                     dbms_output.put_line('员工名--》'||sp_table(0)); 

                  end;

--參照类型

        ---1游标变量

               --实例一  输入部门号。显示全部的员工姓名和他的工资

                       declare

                             --定义游标类型

                             type sp_emp_cursor is ref cursor;

                              --定义游标变量

                             test_cursor sp_emp_cursor; 

                             --定义变量

                             v_ename emp.ename%type;

                             v_sal emp.sal%type;

                         begin 

                              --运行

                              --把test_cursor 和select 结合

                            open test_cursor for select ename,sal  from emp where deptno=&depno;

                            --循环取出

                            loop

                              fetch test_cursor into v_ename,v_sal;

                              --推断是否test——cursor 为空

                               exit when  test_cursor%notfound;

                              dbms_output.put_line('员工名->'||v_ename||'工资->'||v_sal); 

                            end loop;

                         end;

Oracle PL/SQL 编程基础 实例的更多相关文章

  1. Oracle Pl/SQL编程基础

    Pl/SQL简介 提高应用程序的运行性能, 提供模块化的程序设计, 自定义标示符, 具有过程语言控制结构, 良好的兼容性, 处理运行错误. Pl/SQL语言基础 sql是关系数据库的基本操作语言. s ...

  2. oracle PL/SQL编程基础知识

    在oracle中使用pl/sql来扩展SQL的功能,使得SQL能够更加的灵活,功能更加强大,效率更高.pl/sql让sql也能执行判断,循环等操作.主要记录一下pl/sql的基本语法和基本条件判断语句 ...

  3. Oracle数据库编程:PL/SQL编程基础

    2.PL/SQL编程基础: PL/SQL块:        declare        定义部分        begin        执行部分        exception        异 ...

  4. ORACLE PL/SQL编程详解

    ORACLE PL/SQL编程详解 编程详解 SQL语言只是访问.操作数据库的语言,并不是一种具有流程控制的程序设计语言,而只有程序设计语言才能用于应用软件的开发.PL /SQL是一种高级数据库程序设 ...

  5. [强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!)

    原文:[强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!) [强烈推荐]ORACLE PL/SQL编程详解之七: 程序包的创建与应用(聪明在于学习,天 ...

  6. ORACLE PL/SQL编程之八:把触发器说透

    原文:ORACLE PL/SQL编程之八:把触发器说透 ORACLE PL/SQL编程之八: 把触发器说透 大家一定要评论呀,感谢!光发表就花了我将近一个下午. 本篇主要内容如下: 8.1 触发器类型 ...

  7. ORACLE PL/SQL编程之六:把过程与函数说透(穷追猛打,把根儿都拔起!)

    原文:ORACLE PL/SQL编程之六:把过程与函数说透(穷追猛打,把根儿都拔起!) ORACLE PL/SQL编程之六: 把过程与函数说透(穷追猛打,把根儿都拔起!)   继上篇:ORACLE P ...

  8. [推荐]ORACLE PL/SQL编程详解之三:PL/SQL流程控制语句(不给规则,不成方圆)

    原文:[推荐]ORACLE PL/SQL编程详解之三:PL/SQL流程控制语句(不给规则,不成方圆) [推荐]ORACLE PL/SQL编程详解之三: PL/SQL流程控制语句(不给规则,不成方圆) ...

  9. [推荐]ORACLE PL/SQL编程详解之一:PL/SQL 程序设计简介(千里之行,始于足下)

    原文:[推荐]ORACLE PL/SQL编程详解之一:PL/SQL 程序设计简介(千里之行,始于足下) [推荐]ORACLE PL/SQL编程详解之一: PL/SQL 程序设计简介(千里之行,始于足下 ...

随机推荐

  1. 数据库选型之亿级数据量并发访问(MySQL集群)

    刘 勇  Email:lyssym@sina.com 简介 针对实际应用中并发访问MySQL的场景,本文采用多线程对MySQL进行并发读取访问,其中以返回用户所需的数据并显示在终端为测试结束节点,即将 ...

  2. vscode简洁的代码编辑器

    微软去年tuichu的代码编辑神器,vscode很不辞哦,感受还不错.微软也破天荒地跨平台地支持... 支持多种语言 vscode(官方):code.visualstudio.com vscode中文 ...

  3. iOS-高仿微信摇一摇动画效果加震动音效

    概述 摇一摇动画效果 (加震动音效) 详细 代码下载:http://www.demodashi.com/demo/10707.html 众所周知, 微信中的摇一摇功能: 搜索人/歌曲/电视,同样在一些 ...

  4. JPA实体继承实体的映射策略

    注:这里所说的实体指的是@Entity注解的类 继承映射使用@Inheritance来注解.它的strategy属性的取值由枚举InheritanceType来定义(包含SINGLE_TABLE.TA ...

  5. C#中的Invoke和BeginInvoke

    一.Control#Invoke() 和Control#BeginInvoke() 在非UI线程中调用MessageBox.Show()结果是非模态对话框: 在UI线程中调用MessageBox.Sh ...

  6. Ueditor编辑旧文章,从数据库中取出要修改的内容

    Ueditor编辑旧文章,从数据库中取出要修改的内容然后放置到编辑器中: <script type="text/plain" id="editor"> ...

  7. 用Visual Studio 2010开发Android应用

    在开发你的第一个Android应用程序之前,你应该先检查一下是否安装了Android SDK,以及是否创建好了Android模拟器(AVD),如果有不清楚的地方,请先看我以前发布的这篇文章“Andro ...

  8. 在Windows Service上安装运行Redis

    CSDN下载RedisWatcher,运行InstallWatcher.msi,默认安装在C:\Program Files (x86)\RedisWatcher,修改watcher.conf # re ...

  9. 转: Python中的os.path.dirname(__file__)

     (1).当"print os.path.dirname(__file__)"所在脚本是以完整路径被运行的, 那么将输出该脚本所在的完整路径,比如:                 ...

  10. Java+Oracle实现事务——JDBC事务

    J2EE支持JDBC事务.JTA事务和容器事务事务,这里说一下怎样实现JDBC事务. JDBC事务是由Connection对象所控制的,它提供了两种事务模式:自己主动提交和手动提交,默认是自己主动提交 ...