Oracle PL / SQL 存儲過程

PL / SQL存儲過程不返回值。他們執行他們的指示并返回。您不能在賦值語句(如函數)的右側使用存儲過程。

創建存儲過程

以下代碼是一個非常簡單的存儲過程示例。

它基于SYS.DBMS_LOCK包的程序sleep(數量)。

此存儲過程將停止執行指定的秒數。

CREATE OR REPLACE PROCEDURE wait( ain_seconds IN number) is 
begin --  w ww .j  a  va2  s .co mSYS.DBMS_LOCK.sleep(ain_seconds); 
end wait; 
/ declare v_max_line varchar2(32767); 
begin wait(2);
end; 
/ 

注意

創建存儲過程的語法如下:


CREATE [OR REPLACE] PROCEDURE <procedure_name> [( 
<parameter_name_1> [IN] [OUT] <parameter_data_type_1>, 
<parameter_name_2> [IN] [OUT] <parameter_data_type_2>,... 
<parameter_name_N> [IN] [OUT] <parameter_data_type_N> )] IS--the declaration section --  w ww .j  a  va2s  .c  o  m
BEGIN-- the executable section 
EXCEPTION-- the exception-handling section 
END; 
/ 

<procedure_name>是PROCEDURE的名稱;?<parameter_name>是要傳遞的參數的名稱IN,OUT或IN,OUT <parameter_data_type>是相應參數的PL / SQL數據類型。

注意2

關鍵字OR REPLACE周圍的括號表示它們是可選的。

參數的括號表示它們是可選的。

PROCEDURE的塊結構與匿名塊相同,除了CREATE PROCEDURE關鍵字和可選參數。

存儲過程不同于函數,因為它沒有RETURN參數。

實例2

以下代碼為SYS.DBMS_OUTPUT.put_line()創建一個warpper。

create or replace PROCEDURE pl( aiv_text in varchar2 ) is 
begin --  www  . jav a2 s  . c o mSYS.DBMS_OUTPUT.put_line(aiv_text); 
end pl; 
/ declare v_max_line varchar2(32767); 
begin for i in 1..10 loop v_max_line := v_max_line || ' a'; end loop; pl('Test a line of text.'); pl(to_date('20200101', 'YYYYMMDD')); end; 
/ 

?CSDN:程序猿 寄語:
1、作為一個真正的程序員,首先應該尊重編程,熱愛你所寫下的程序,他是你的伙伴,而不是工具。
2、程序員可以讓步,卻不可以退縮,可以羞澀,卻不可以軟弱,總之,程序員必須是勇敢的。
3、編程是一種單調的生活,因此程序員比普通人需要更多的關懷,更多的友情。
4、程序不是年輕的專利,但是,他屬于年輕。
5、沒有情調,不懂浪漫,也許這是程序員的一面,但擁有樸實無華的愛是他們的另一面。
6、一個好漢三個幫,程序員同樣如此。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/38477.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/38477.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/38477.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

在 C++的跨平臺開發中,如何處理不同操作系統和編譯器之間的細微差異,以確保程序能夠穩定且高效地運行?

在 C 的跨平臺開發中&#xff0c;處理不同操作系統和編譯器之間的細微差異是非常重要的。以下是一些處理差異的技巧&#xff1a; 使用條件編譯&#xff1a;使用預處理指令&#xff0c;根據不同的操作系統和編譯器來編寫不同的代碼。 #if defined(_WIN32)// Windows 特定代碼 …

kafka的工作原理與常見問題

定義 kafka是一個分布式的基于發布/訂閱模式的消息隊列&#xff08;message queue&#xff09;&#xff0c;主要應用于大數據的實時處理領域 消息隊列工作原理 kafka的組成結構 kafka的基礎架構主要有broker、生產者、消費者組構成&#xff0c;還包括zookeeper. 生產者負責發送…

算法09 日期相關模擬算法【C++實現】

這是《C算法寶典》算法篇的第09節文章啦~ 如果你之前沒有太多C基礎&#xff0c;請點擊&#x1f449;專欄&#xff1a;C語法入門&#xff0c;如果你C語法基礎已經爐火純青&#xff0c;則可以進階算法&#x1f449;專欄&#xff1a;算法知識和數據結構&#x1f449;專欄&#xff…

計算斜率,判斷斜率

#include <stdio.h> #include <stdlib.h> #include <math.h> #include <stdbool.h>// 定義常量 #define LOW_COOK_WINDOW_SIZE 20 // 滑動窗口大小&#xff0c;10個樣本點&#xff08;10秒&#xff09; #define LOW_COOK_SLOPE…

Java代碼生成器(開源版本)

一、在線地址 Java在線代碼生成器&#xff1a;在線訪問 二、頁面截圖 三、核心功能 支持Mybatis、MybatisPlus、Jpa代碼生成使用 antlr4 解析SQL語句&#xff0c;保證了SQL解析的成功率支持自定義包名、作者名信息支持自定義方法名、接口地址支持自定義選擇是否生成某個方法…

16-Python Pandas聚合函數

Python Pandas聚合函數 窗口函數可以與聚合函數一起使用&#xff0c;聚合函數指的是對一組數據求總和、最大值、最小值以及平均值的操作。 應用聚合函數 首先讓我們創建一個 DataFrame 對象&#xff0c;然后對聚合函數進行應用。 import pandas as pd import numpy as np d…

SQL中的子查詢和CTE(with ....as..)

第一次看到with as 這種類似于python中讀文件的寫法還是挺疑惑的&#xff0c;其實它是CTE&#xff0c;功能和子查詢很類似但又有不同點&#xff0c;在實際應用場景中具有著獨特作用。 子查詢 子查詢是在主查詢中的嵌套查詢&#xff0c;可以出現在SELECT、FROM、WHERE等子句中…

ai除安卓手機版APP軟件一鍵操作自動渲染去擦消稀缺資源下載

安卓手機版&#xff1a;點擊下載 蘋果手機版&#xff1a;點擊下載 電腦版&#xff08;支持Mac和Windows&#xff09;&#xff1a;點擊下載 一款全新的AI除安卓手機版APP&#xff0c;一鍵操作&#xff0c;輕松實現自動渲染和去擦消效果&#xff0c;稀缺資源下載 1、一鍵操作&…

數學建模(1):期末大亂燉

1 概述&#xff01;&#xff01; 1.1 原型和模型 原型&#xff1a;客觀存在的研究對象稱為原型&#xff0c;也稱為“系統”、“過程”。 機械系統、電力系統、化學反應過程、生產銷售過程等都是原型&#xff1b; 研究原型的結構和原理&#xff0c; 從而進行優化、預測、評價…

Perl編程藝術:深入探索Tie機制的魔力

&#x1f31f; Perl編程藝術&#xff1a;深入探索Tie機制的魔力 在Perl的世界里&#xff0c;tie功能是一種極其強大的特性&#xff0c;它允許程序員將變量綁定到一個對象上&#xff0c;從而改變這個變量的默認行為。這種機制為變量提供了一種代理訪問方式&#xff0c;使得變量…

Jedis、Lettuce、RedisTemplate連接中間件

jedis就像jdbc一樣&#xff0c;用于兩個端直接的連接。 1.創建Spring項目 這里不過多贅述... 2.導入連接工具jedis 在pom文件中導入jedis的依賴。 <dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version&…

結合數據索引結構看SQL的真實執行過程

引言 關于數據庫設計與優化的前幾篇文章中&#xff0c;我們提到了數據庫設計優化應該遵守的指導原則、數據庫底層的索引組織結構、數據庫的核心功能組件以及SQL的解析、編譯等。這些其實都是在為SQL的優化、執行的理解打基礎。 今天這篇文章&#xff0c;我們以MySQL中InnoDB存…

vim卡死

有些時候使用vim的時候莫名其妙的會卡死&#xff0c;導致輸入不了內容。查了一下資料發現&#xff0c;其實并不是vim卡死&#xff0c;而是在使用vim的工程中帶入了許多Windows上的使用習慣&#xff0c;比如“Ctrl-s”保存等&#xff0c;這可能會與Linux平臺的有些快捷鍵沖突。c…

Oracle PL / SQL 表 table

關系數據庫允許您在數據庫管理系統&#xff08;DBMS&#xff09;中存儲多個表。 您可以使用計算機上的查詢語言來操作表中的數據。 當前的查詢語言是結構化查詢語言&#xff08;SQL&#xff09;。 SQL是一組無關的命令&#xff0c;用于操作關系數據庫管理系統&#xff08;RD…

CleanMyMacX2024免費且強大的mac電腦系統優化工具

如果你的Mac電腦出現了存儲空間不足、運行緩慢、電池電量消耗過快等問題&#xff0c;那么CleanMyMacX這款軟件或許能為你提供解決方案。作為一款強大的系統優化工具&#xff0c;它能夠幫助用戶清理垃圾文件、優化內存和電池使用&#xff0c;從而提升Mac的性能表現&#xff0c;讓…

后端之路第三站(Mybatis)——XML文件操作sql

一、XML映射文件是啥 前面我們學過了在Mapper接口用注解的方式來操作sql語句 那么XML映射文件就另一種操作sql語句的方法 為什么還要有這么個玩意&#xff1f; 我簡單說就是&#xff1a;如果有的sql特別復雜的話&#xff0c;比如需要【動態sql】的話&#xff0c;就得用到XM…

【Android面試八股文】Fragment的add和replace的區別,分別對Fragment的生命周期有什么影響?

文章目錄 一、Fragment的add和replace的區別 ,分別對Fragment的生命周期有什么影響?1.1 `add` 方法1.2 `replace` 方法1.3 應用場景1.4 Fragment事務操作提交流程1.5 replace操作的本質是不是就是remove操作和add操作的組合?1.6 示例代碼:將一個已經存在的 `FragmentA` 替換…

電腦開機之后,鍵盤鼠標需要重新插拔才能正常使用?

前言 小白平時修電腦修得多&#xff0c;總是會遇到各種各樣的奇葩問題。這不&#xff0c;又有一位小伙伴來咨詢&#xff1a;電腦開機之后&#xff0c;鍵盤鼠標都不能用&#xff0c;需要重新插拔一下才能正常使用。 嘖嘖嘖&#xff0c;真的是很奇怪的問題&#xff0c;基本上沒見…

分頁緩存與下拉刷新的整合原理 - DoraPageDatabaseCacheRepository

何為分頁緩存&#xff1f; 顧名思義&#xff0c;分頁緩存就是邊分頁邊緩存&#xff0c;分頁通常使用下拉刷新控件實現&#xff0c;而緩存通常說的是指磁盤緩存&#xff0c;即保存到數據庫中&#xff0c;數據庫本身也是一個索引文件。 為什么緩存還要分頁&#xff1f; 在很大…

SSH 無密登錄配置流程

一、免密登錄原理 非對稱加密&#xff1a; 由于對稱加密的存在弊端&#xff0c;就產生了非對稱加密&#xff0c;非對稱加密中有兩個密鑰&#xff1a;公鑰和私鑰。公鑰由私鑰產生&#xff0c;但卻無法推算出私鑰&#xff1b;公鑰加密后的密文&#xff0c;只能通過對應的私鑰來解…