oracle存储过程的写法是【CREATE OR REPLACE PROCEDURE 存储过程名(param1 in type,param2 out type)IS 变量1 类型(值范围);BEGIN select count...】。
推荐教程:oracle教程
1、存储过程的基本语法:
CREATE OR REPLACE PROCEDURE 存储过程名(param1 in type,param2 out type) IS 变量1 类型(值范围); 变量2 类型(值范围); BEGIN select count(*) into 变量1 from 表名 where 列名=param1; if (判断条件) then select 列名 into 变量2 from 表名 where 列名=param1; DBMS_OUTPUT.put_line('打印信息'); Elsif (判断条件) then dbms_output.put_line('打印信息'); Else Raise 异常名 (NO_DATA_FOUND); End if; Exception When others then Rollback; END;
2、已命名的异常:
命名的系统异常 产生原因 ACCESS_INTO_NULL 未定义对象 CASE_NOT_FOUND CASE中若未包含相应的WHEN,并且没有设置ELSE时 COLLECTION_IS_NULL 集合元素未初始化 CURSER_ALREDAY_OPEN 游标已经打开 DUP_VAL_NO_INDEX 唯一索引对应的列上有重复的列 INVALID_CUSER 在不合法的游标上操作 INVALID_NUMBER 内嵌的SQL语句不能将字符转换为数字 NO_DATA_FOUND 使用select into 未返回行,或应用索引表未初始化 TOO_MANY_ROWS 执行select into 时,结果集超过一行 ZERO_DIVIDE 除数为0 SUBSCRIPT_BEYOND_COUNT 元素下标超过嵌套表或VARRAY的最大值 SUBSCRIPT_OUTSIDE_LIMIT 使用嵌套表或VARRAY时,将下标指定为负数 VALUE_ERROR 赋值时,变量长度不足以容纳实际数量 LOGIN_DENIED PL/SQL应用程序连接到ORACLE数据库时,提供了不正确的用户名和密码 NO_LOGGED_ON PL/SQL应用程序在没有连接ORACLE数据库的情况下访问数据 PROGRAM_ERROR PL/SQL内部问题,可能需要重装数据字典& PL/SQL系统包 ROWTYPE_MISMATCH 宿主游标变量与PL/SQL游标变量的返回类型不兼容 SELF_IS_NULL 使用对象类型时,在NULL对象上调用对象方法 STORAGE_ERROR 运行PL/SQL时,超出内存空间 SYS_INVALID_ID 无效的ROWID字符串 TIMEOUT_ON_RESOURCE ORACLE在等待资源时超时
3、实际例子
2.1 没有参数的过程
create or replace procedure test_count is v_total int; v_date varchar(20); begin select count(*) into v_total from dual; select to_char(sysdate,'yyyy-mm-dd') into v_date from dual; DBMS_OUTPUT.put_line('总人数:'||v_total); DBMS_OUTPUT.put_line('当前时间:'||v_date); end;
调用方法:
begin test_count; end;
2.2 仅带传入参数的过程
create or replace procedure test_count1(v_id in varchar2) as v_name varchar(100); begin select c_name into v_name from tb_store where c_stono=v_id; DBMS_OUTPUT.put_line(v_id||'店的名称为:'||v_name); exception when no_data_found then dbms_output.put_line('no_data_found'); end;
调用方法:
begin test_count1(11910); end;
2.3 仅带输出参数的过程
create or replace procedure test_count2(v_name out varchar2) is begin select c_name into v_name from tb_store where c_stono='1101'; exception when no_data_found then dbms_output.put_line('no_data_found'); end;
调用方法:
declare v_name varchar(200); begin test_count2(v_name); dbms_output.put_line(v_name); end;
2.4 带输入参数和输出参数的存储过程
create or replace procedure test_count3(v_id in int,v_name out varchar2) is begin select c_name into v_name from tb_store where c_stono=v_id; dbms_output.put_line(v_name); exception when no_data_found then dbms_output.put_line('no_data_found'); end;
调用方法:
declare v_name varchar(200); begin test_count3('1101',v_name); end;
以上是oracle存储过程的写法的详细内容。更多信息请关注PHP中文网其他相关文章!

方法:1、利用“select*from user_indexes where table_name=表名”语句查询表中索引;2、利用“select*from all_indexes where table_name=表名”语句查询所有索引。

oracle asm指的是“自动存储管理”,是一种卷管理器,可自动管理磁盘组并提供有效的数据冗余功能;它是做为单独的Oracle实例实施和部署。asm的优势:1、配置简单、可最大化推动数据库合并的存储资源利用;2、支持BIGFILE文件等。

在Oracle中,可利用lsnrctl命令查询端口号,该命令是Oracle的监听命令;在启动、关闭或重启oracle监听器之前可使用该命令检查oracle监听器的状态,语法为“lsnrctl status”,结果PORT后的内容就是端口号。

在oracle中,可以利用“TO_SINGLE_BYTE(String)”将全角转换为半角;“TO_SINGLE_BYTE”函数可以将参数中所有多字节字符都替换为等价的单字节字符,只有当数据库字符集同时包含多字节和单字节字符的时候有效。

方法:1、利用“LOWER(字段值)”将字段转为小写,或者利用“UPPER(字段值)”将字段转为大写;2、利用“REGEXP_LIKE(字符串,正则表达式,'i')”,当参数设置为“i”时,说明进行匹配不区分大小写。

在oracle中,可以利用“drop sequence sequence名”来删除sequence;sequence是自动增加数字序列的意思,也就是序列号,序列号自动增加不能重置,因此需要利用drop sequence语句来删除序列。

在oracle中,可以利用“select ... From all_tab_columns where table_name=upper('表名') AND owner=upper('数据库登录用户名');”语句查询数据库表的数据类型。

方法:1、利用“alter system set sessions=修改后的数值 scope=spfile”语句修改session参数;2、修改参数之后利用“shutdown immediate – startup”语句重启服务器即可生效。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

SublimeText3汉化版
中文版,非常好用

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能