数据库存储过程 (简单入门)

本贴最后更新于 2882 天前,其中的信息可能已经天翻地覆

本文由黑壳网原创
本文章来源数据库存储过程(简单入门)~黑壳网

壳叔搞笑段子~
一个人坐上出租汽车,当接近自己家时,发现身上已分文不剩。“在这里停下,”他喊道,“我到路旁的小卖店买包香烟就回来。我有 10 英镑掉在车上了,因为车内太暗,一时找不到,先借我一点零钱买烟吧。”他接过钱快步进了小卖店,回头一看,就像他预想的那样,出租车飞快地开跑了。

![0726defc3f3c4e6eb19f6b8ccbdacb18-timg.jpeg](//oot0mlws2.bkt.clouddn.com//file/2017/4/0726defc3f3c4e6eb19f6b8ccbdacb18-timg.jpeg) 今天,刚把oracle装在虚拟机里,然后由感而发,写了一篇过于入门的存储过程文章。

我先简答科普一下存储过程。

存储过程相当于数据库中的子程序。

简单讲几句了解一下存储过程的好处,例如做一个功能,如果你在前台处理处理的话,可能会和数据库涉及多次交流,但是如果你用存储过程的话,就只有一次。从相应时间上来说,涉及一次肯定比涉及多次的有优势。也就是说在开发过程当中存储过程有可以提高运行效率的好处。另外,程序容易出现 bug 不稳定,而存储过程,只要数据库不出现问题,基本上是不会出现什么问题的,从另一个角度来说,或者从安全的角度来说使用了存储过程的系统更加稳定。
i. 存储过程与存储函数的概念

在数据库中,有很多的对象,这些对象包含了(表、视图、索引、序列、同义词)和(存储过程、存储函数)

是指在数据库中供所有用户程序调用的子程序,叫存储过程和存储函数

存储过程和存储函数的相同点:完成指定的功能程序

存储过程和存储函数的区别:是否用 return 语句返回值

存储过程不能通过 return 返回一个函数的值,这一点是存储过程和存储函数最大的区别。初此之外,我们完全可以当存储过程和存储函数是一样的。

ii. 存储过程的创建
用 CREATE PROCEDURE 命令建立存储过程和存储函数
语法

CREATE [OR REPLACE] PROCEDURE 存储过程名(参数列表)
-- sql 语句通知 oracle 数据库创建 (存储过程名) 的存储过程 ,如果有就覆盖它 ,REPLACE 表示是否覆盖。
AS --说明部分,即使没有说明也不可以省略 AS
PLSQL --子程序体;

注: 存储过程只能创建和替换,不可以修改!!! 存储函数同样 我创建一个存储过程示例 b04f00754fd04deb9e127e40b05fb530.png 存储过程编译完成之后,会生成一个新的名为bhusk的存储过程

点击运行

打印输出,还有一种调用存储过程的方式,适合比较要逼格的同学

首先打开以下界面

输入 sqlplus 进入输入 oracle 用户密码控制台界面

确认 用户名和口令输入无误~ 按下 enter 回车

进入以下界面,说明你已经成功进入 sqlplus 了,如果没有百度科普一下,解决问题

执行 set serveroutput on 命令设置环境变量 serveroutput 为打开状态,从而使得 pl/sql 程序能够在 sqlplus 中输出结果!


调用存储过程有两种命令
1、execute 可以缩写 exce 可以说明是 sqlplus 语句
示例

2、

begin
bhusk();
bhusk();
end;
/

这个可以在命令中可多次执行存储过程。

总结:本次主要是存储的入门,让你知道存储过程创建以及调用。后期会写参数的使用以及,然后慢慢深入的文章。

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • seanlee

    图片挂掉了。。。

    1 回复
  • 其他回帖
  • ykz200 via macOS
    作者

    由于网站的 https 加密协议导致不能正常访问,已改回 http,现在可以正常观看。
    感谢你的评论 黑壳网 http://www.bhusk.com

ykz200
我是壳叔,我正在想一个很棒的idea 北京

推荐标签 标签

  • wolai

    我来 wolai:不仅仅是未来的云端笔记!

    2 引用 • 14 回帖 • 4 关注
  • 微软

    微软是一家美国跨国科技公司,也是世界 PC 软件开发的先导,由比尔·盖茨与保罗·艾伦创办于 1975 年,公司总部设立在华盛顿州的雷德蒙德(Redmond,邻近西雅图)。以研发、制造、授权和提供广泛的电脑软件服务业务为主。

    8 引用 • 44 回帖 • 3 关注
  • 浅吟主题

    Jeffrey Chen 制作的思源笔记主题,项目仓库:https://github.com/TCOTC/Whisper

    1 引用 • 28 回帖
  • Tomcat

    Tomcat 最早是由 Sun Microsystems 开发的一个 Servlet 容器,在 1999 年被捐献给 ASF(Apache Software Foundation),隶属于 Jakarta 项目,现在已经独立为一个顶级项目。Tomcat 主要实现了 JavaEE 中的 Servlet、JSP 规范,同时也提供 HTTP 服务,是市场上非常流行的 Java Web 容器。

    162 引用 • 529 回帖 • 6 关注
  • Quicker

    Quicker 您的指尖工具箱!操作更少,收获更多!

    36 引用 • 155 回帖 • 2 关注
  • PostgreSQL

    PostgreSQL 是一款功能强大的企业级数据库系统,在 BSD 开源许可证下发布。

    22 引用 • 22 回帖 • 1 关注
  • OkHttp

    OkHttp 是一款 HTTP & HTTP/2 客户端库,专为 Android 和 Java 应用打造。

    16 引用 • 6 回帖 • 83 关注
  • 人工智能

    人工智能(Artificial Intelligence)是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门技术科学。

    153 引用 • 285 回帖
  • 笔记

    好记性不如烂笔头。

    311 引用 • 796 回帖
  • Thymeleaf

    Thymeleaf 是一款用于渲染 XML/XHTML/HTML5 内容的模板引擎。类似 Velocity、 FreeMarker 等,它也可以轻易的与 Spring 等 Web 框架进行集成作为 Web 应用的模板引擎。与其它模板引擎相比,Thymeleaf 最大的特点是能够直接在浏览器中打开并正确显示模板页面,而不需要启动整个 Web 应用。

    11 引用 • 19 回帖 • 382 关注
  • sts
    2 引用 • 2 回帖 • 222 关注
  • BookxNote

    BookxNote 是一款全新的电子书学习工具,助力您的学习与思考,让您的大脑更高效的记忆。

    笔记整理交给我,一心只读圣贤书。

    1 引用 • 1 回帖
  • 博客

    记录并分享人生的经历。

    273 引用 • 2388 回帖
  • LaTeX

    LaTeX(音译“拉泰赫”)是一种基于 ΤΕΧ 的排版系统,由美国计算机学家莱斯利·兰伯特(Leslie Lamport)在 20 世纪 80 年代初期开发,利用这种格式,即使使用者没有排版和程序设计的知识也可以充分发挥由 TeX 所提供的强大功能,能在几天,甚至几小时内生成很多具有书籍质量的印刷品。对于生成复杂表格和数学公式,这一点表现得尤为突出。因此它非常适用于生成高印刷质量的科技和数学类文档。

    12 引用 • 54 回帖 • 17 关注
  • 30Seconds

    📙 前端知识精选集,包含 HTML、CSS、JavaScript、React、Node、安全等方面,每天仅需 30 秒。

    • 精选常见面试题,帮助您准备下一次面试
    • 精选常见交互,帮助您拥有简洁酷炫的站点
    • 精选有用的 React 片段,帮助你获取最佳实践
    • 精选常见代码集,帮助您提高打码效率
    • 整理前端界的最新资讯,邀您一同探索新世界
    488 引用 • 384 回帖 • 5 关注
  • PWA

    PWA(Progressive Web App)是 Google 在 2015 年提出、2016 年 6 月开始推广的项目。它结合了一系列现代 Web 技术,在网页应用中实现和原生应用相近的用户体验。

    14 引用 • 69 回帖 • 175 关注
  • golang

    Go 语言是 Google 推出的一种全新的编程语言,可以在不损失应用程序性能的情况下降低代码的复杂性。谷歌首席软件工程师罗布派克(Rob Pike)说:我们之所以开发 Go,是因为过去 10 多年间软件开发的难度令人沮丧。Go 是谷歌 2009 发布的第二款编程语言。

    498 引用 • 1395 回帖 • 260 关注
  • WebClipper

    Web Clipper 是一款浏览器剪藏扩展,它可以帮助你把网页内容剪藏到本地。

    3 引用 • 9 回帖 • 5 关注
  • Laravel

    Laravel 是一套简洁、优雅的 PHP Web 开发框架。它采用 MVC 设计,是一款崇尚开发效率的全栈框架。

    20 引用 • 23 回帖 • 738 关注
  • 深度学习

    深度学习(Deep Learning)是机器学习的分支,是一种试图使用包含复杂结构或由多重非线性变换构成的多个处理层对数据进行高层抽象的算法。

    54 引用 • 40 回帖
  • QQ

    1999 年 2 月腾讯正式推出“腾讯 QQ”,在线用户由 1999 年的 2 人(马化腾和张志东)到现在已经发展到上亿用户了,在线人数超过一亿,是目前使用最广泛的聊天软件之一。

    45 引用 • 557 回帖
  • Eclipse

    Eclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。

    76 引用 • 258 回帖 • 635 关注
  • DevOps

    DevOps(Development 和 Operations 的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。

    56 引用 • 25 回帖 • 5 关注
  • AngularJS

    AngularJS 诞生于 2009 年,由 Misko Hevery 等人创建,后为 Google 所收购。是一款优秀的前端 JS 框架,已经被用于 Google 的多款产品当中。AngularJS 有着诸多特性,最为核心的是:MVC、模块化、自动化双向数据绑定、语义化标签、依赖注入等。2.0 版本后已经改名为 Angular。

    12 引用 • 50 回帖 • 499 关注
  • WordPress

    WordPress 是一个使用 PHP 语言开发的博客平台,用户可以在支持 PHP 和 MySQL 数据库的服务器上架设自己的博客。也可以把 WordPress 当作一个内容管理系统(CMS)来使用。WordPress 是一个免费的开源项目,在 GNU 通用公共许可证(GPLv2)下授权发布。

    66 引用 • 114 回帖 • 204 关注
  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    345 引用 • 724 回帖
  • Unity

    Unity 是由 Unity Technologies 开发的一个让开发者可以轻松创建诸如 2D、3D 多平台的综合型游戏开发工具,是一个全面整合的专业游戏引擎。

    25 引用 • 7 回帖 • 137 关注