热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

Oracle数据库教程:PL/SQL笔记

PLSQL(procedurallanguagesql):是oracle基于标准SQL语言的扩展,在PLSQL中你可以嵌套sql语句、定义变量、定义常量、使用逻

PL/SQL(procedural language/sql):是oracle基于标准SQL语言的扩展,在PL/SQL中你可以嵌套sql语句、定义变量、定义常量、使用逻

  • 基于以上表myinfo

    ),既然是扩展,当然会使得他的功能更加强大!

    PL/SQL是强大的数据库过程语言!

    重要的是:重要的是PL/SQL紧密的结合在Oracle数据库里面。

    PL/SQL是Oracle数据库使用的三种语言的其中之一,另外两个是SQL和Java。

    功能近似PL/SQL的程序语言和其他关系型数据库:Sybase ASE、Microsoft SQL Server的Transact-SQL,PostgreSQL数据库的PL/pgSQL(模仿PL/SQL)和IBM DB2的SQL PL[1],都符合ISO SQL的SQL/PSM标准。

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

    pl/sql的优点:

    提高应用程序的运行性能、模块化设计、减少网络传输量、提高安全性

    (传统的数据库操作,我们想想:SQL语句写在java程序访问数据库,首先获得连接,编译SQL语句,使得数据库能够认识你的SQL语句,这里每次编译就浪费了一些时间,当数据访问量很大的时候,你的程序性能就比较差了!这里如果我们把某些操作写为一个过程,比如分页、转账过程(功能划分为一个模块,由专人负责维护……)。就可以使得我们的程序性能大大提高,从而数据库操作作为一个模块,当java程序调用时就是调用已经编译的SQL语句,所以在进行程序优化时可以考虑用存储过程进行优化。)

    【当然还有其他有点好处,欢迎补充】

    缺点:

    当需要换数据库时,移植性存在缺陷

    |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||


    PL/SQL编写规范:

    A:

    单行注释:--

    多行注释:/*……*/

    B:

    标识符的命名规范:

    a.定义变量,建议用v_作为前缀, 例:v_sale

    b.定义常量,,建议用c_作为前缀,例:c_rate

    c.定义游标,建议用_cursor作为后缀例:emp_cursor

    d.定义例外,建议用e_作为前缀例:e_error

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

    PL/SQL是以块为基本单位,块分类{主要有存储过程,函数,触发器,包}

    块(block)的介绍:

    上面说了,PL/SQL是以块为基本单位,,我们编写PL/SQL就是在编写块,简单的应用功能,我们可能只需要一个PL/SQL块就可以实现,复杂的功能就需要多个块了,块可以嵌套。

    块由三部分组成:{定义部分、执行部分、例外处理部分},即:

    declare (可选)

    /*声明部分---定义常量、变量。游标、例外、复杂数据类型*/

    begin (必须滴)

    /*执行部分---需要执行的pl/sql语句和SQL语句*/

    exception(可选的)

    /*处理运行的各种错误*/

    end;(必须滴)

    编写一个简单的块先:

    例子,

    例子, 例子,外加显示密码:

    这里都会弹出一个框,让输入就是psw的值,where passwd=&psw

    例外的情况,如果查询不到数据呢?oracle中会抛出异常,

    这里我们就可以使用例外了,Exception

    linux

    推荐阅读
    • 深入理解 SQL 视图、存储过程与事务
      本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
    • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
    • 数据库内核开发入门 | 搭建研发环境的初步指南
      本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
    • 深入理解OAuth认证机制
      本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
    • 本文详细分析了JSP(JavaServer Pages)技术的主要优点和缺点,帮助开发者更好地理解其适用场景及潜在挑战。JSP作为一种服务器端技术,广泛应用于Web开发中。 ... [详细]
    • 优化ListView性能
      本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
    • Valve 发布 Steam Deck 的新版 Windows 驱动程序
      Valve 最新发布了针对 Steam Deck 掌机的 Windows 驱动程序,旨在提升其在 Windows 环境下的兼容性、安全性和性能表现。 ... [详细]
    • Windows服务与数据库交互问题解析
      本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
    • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
    • 三星W799在2011年的表现堪称经典,以其独特的双屏设计和强大的功能引领了双模手机的潮流。本文详细介绍其配置、功能及锁屏设置。 ... [详细]
    • 本文探讨了Hive中内部表和外部表的区别及其在HDFS上的路径映射,详细解释了两者的创建、加载及删除操作,并提供了查看表详细信息的方法。通过对比这两种表类型,帮助读者理解如何更好地管理和保护数据。 ... [详细]
    • 本文总结了汇编语言中第五至第八章的关键知识点,涵盖间接寻址、指令格式、安全编程空间、逻辑运算指令及数据重复定义等内容。通过详细解析这些内容,帮助读者更好地理解和应用汇编语言的高级特性。 ... [详细]
    • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
    • 数据管理权威指南:《DAMA-DMBOK2 数据管理知识体系》
      本书提供了全面的数据管理职能、术语和最佳实践方法的标准行业解释,构建了数据管理的总体框架,为数据管理的发展奠定了坚实的理论基础。适合各类数据管理专业人士和相关领域的从业人员。 ... [详细]
    • 优化版Windows 10 LTSC 21H2企业版:适用于低内存设备
      此版本为经过优化的Windows 10 LTSC 21H2企业版,特别适合低内存配置的计算机。它基于官方版本进行了精简和性能优化,确保在资源有限的情况下依然能够稳定运行。 ... [详细]
    author-avatar
    315热点关注
    这个家伙很懒,什么也没留下!
    PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有