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

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

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

壳叔搞笑段子~
一个人坐上出租汽车,当接近自己家时,发现身上已分文不剩。“在这里停下,”他喊道,“我到路旁的小卖店买包香烟就回来。我有 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
    作者

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

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

推荐标签 标签

  • CSDN

    CSDN (Chinese Software Developer Network) 创立于 1999 年,是中国的 IT 社区和服务平台,为中国的软件开发者和 IT 从业者提供知识传播、职业发展、软件开发等全生命周期服务,满足他们在职业发展中学习及共享知识和信息、建立职业发展社交圈、通过软件开发实现技术商业化等刚性需求。

    14 引用 • 155 回帖 • 1 关注
  • SQLite

    SQLite 是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是全世界使用最为广泛的数据库引擎。

    4 引用 • 7 回帖 • 2 关注
  • Logseq

    Logseq 是一个隐私优先、开源的知识库工具。

    Logseq is a joyful, open-source outliner that works on top of local plain-text Markdown and Org-mode files. Use it to write, organize and share your thoughts, keep your to-do list, and build your own digital garden.

    4 引用 • 55 回帖 • 8 关注
  • Markdown

    Markdown 是一种轻量级标记语言,用户可使用纯文本编辑器来排版文档,最终通过 Markdown 引擎将文档转换为所需格式(比如 HTML、PDF 等)。

    164 引用 • 1451 回帖
  • danl
    64 关注
  • GraphQL

    GraphQL 是一个用于 API 的查询语言,是一个使用基于类型系统来执行查询的服务端运行时(类型系统由你的数据定义)。GraphQL 并没有和任何特定数据库或者存储引擎绑定,而是依靠你现有的代码和数据支撑。

    4 引用 • 3 回帖 • 20 关注
  • 域名

    域名(Domain Name),简称域名、网域,是由一串用点分隔的名字组成的 Internet 上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位(有时也指地理位置)。

    43 引用 • 208 回帖
  • Vditor

    Vditor 是一款浏览器端的 Markdown 编辑器,支持所见即所得、即时渲染(类似 Typora)和分屏预览模式。它使用 TypeScript 实现,支持原生 JavaScript、Vue、React 和 Angular。

    314 引用 • 1667 回帖 • 2 关注
  • 酷鸟浏览器

    安全 · 稳定 · 快速
    为跨境从业人员提供专业的跨境浏览器

    3 引用 • 59 回帖 • 25 关注
  • 锤子科技

    锤子科技(Smartisan)成立于 2012 年 5 月,是一家制造移动互联网终端设备的公司,公司的使命是用完美主义的工匠精神,打造用户体验一流的数码消费类产品(智能手机为主),改善人们的生活质量。

    4 引用 • 31 回帖 • 10 关注
  • Hexo

    Hexo 是一款快速、简洁且高效的博客框架,使用 Node.js 编写。

    21 引用 • 140 回帖 • 30 关注
  • IPFS

    IPFS(InterPlanetary File System,星际文件系统)是永久的、去中心化保存和共享文件的方法,这是一种内容可寻址、版本化、点对点超媒体的分布式协议。请浏览 IPFS 入门笔记了解更多细节。

    20 引用 • 245 回帖 • 230 关注
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    710 引用 • 1173 回帖 • 171 关注
  • 支付宝

    支付宝是全球领先的独立第三方支付平台,致力于为广大用户提供安全快速的电子支付/网上支付/安全支付/手机支付体验,及转账收款/水电煤缴费/信用卡还款/AA 收款等生活服务应用。

    29 引用 • 347 回帖
  • InfluxDB

    InfluxDB 是一个开源的没有外部依赖的时间序列数据库。适用于记录度量,事件及实时分析。

    2 引用 • 56 关注
  • 星云链

    星云链是一个开源公链,业内简单的将其称为区块链上的谷歌。其实它不仅仅是区块链搜索引擎,一个公链的所有功能,它基本都有,比如你可以用它来开发部署你的去中心化的 APP,你可以在上面编写智能合约,发送交易等等。3 分钟快速接入星云链 (NAS) 测试网

    3 引用 • 16 回帖
  • 负能量

    上帝为你关上了一扇门,然后就去睡觉了....努力不一定能成功,但不努力一定很轻松 (° ー °〃)

    85 引用 • 1201 回帖 • 449 关注
  • 创业

    你比 99% 的人都优秀么?

    82 引用 • 1398 回帖 • 1 关注
  • Google

    Google(Google Inc.,NASDAQ:GOOG)是一家美国上市公司(公有股份公司),于 1998 年 9 月 7 日以私有股份公司的形式创立,设计并管理一个互联网搜索引擎。Google 公司的总部称作“Googleplex”,它位于加利福尼亚山景城。Google 目前被公认为是全球规模最大的搜索引擎,它提供了简单易用的免费服务。不作恶(Don't be evil)是谷歌公司的一项非正式的公司口号。

    49 引用 • 192 回帖
  • Android

    Android 是一种以 Linux 为基础的开放源码操作系统,主要使用于便携设备。2005 年由 Google 收购注资,并拉拢多家制造商组成开放手机联盟开发改良,逐渐扩展到到平板电脑及其他领域上。

    333 引用 • 323 回帖 • 67 关注
  • 前端

    前端技术一般分为前端设计和前端开发,前端设计可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括 HTML、CSS 以及 JavaScript 等。

    247 引用 • 1347 回帖
  • Pipe

    Pipe 是一款小而美的开源博客平台。Pipe 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    131 引用 • 1114 回帖 • 150 关注
  • API

    应用程序编程接口(Application Programming Interface)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。

    76 引用 • 421 回帖
  • Sandbox

    如果帖子标签含有 Sandbox ,则该帖子会被视为“测试帖”,主要用于测试社区功能,排查 bug 等,该标签下内容不定期进行清理。

    370 引用 • 1215 回帖 • 582 关注
  • 链滴

    链滴是一个记录生活的地方。

    记录生活,连接点滴

    131 引用 • 3644 回帖 • 1 关注
  • ZooKeeper

    ZooKeeper 是一个分布式的,开放源码的分布式应用程序协调服务,是 Google 的 Chubby 一个开源的实现,是 Hadoop 和 HBase 的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。

    59 引用 • 29 回帖 • 21 关注
  • BookxNote

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

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

    1 引用 • 1 回帖