一:oracle系统包—-dbms_output用法

本文详细介绍了Oracle数据库中DBMS_OUTPUT包的功能和使用方法,包括如何启用、禁用输出,以及通过put、put_line等过程向客户端输出信息。同时提供了多个示例,帮助读者更好地理解和掌握DBMS_OUTPUT包。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

dbms_output包主要用于调试pl/sql程序,或者在sql*plus命令中显示信息(displaying message)和报表,譬如我们可以写一个简单的匿名pl/sql程序块,而该块出于某种目的使用dbms_output包来显示一些信息。

涉及到的知识点如下:
1、enable:在serveroutput on的情况下,用来使dbms_output生效(默认即打开)
2、disable:在serveroutput on的情况下,用来使dbms_output失效
3、put:将内容写到内存,等到put_line时一起输出
4、put_line:不用多说了,输出字符
5、new_line:作为一行的结束,可以理解为写入buffer时的换行符
6、get_line(value, index):获取缓冲区的单行信息
7、get_lines(array, index):以数组形式来获取缓冲区的多行信息

需要注意以下几点:
1、set serveroutput on:如果要在sqlplus中看到dbms_output的输出,则必须设置该参数值为on
2、每行能容纳的最大值是32767bytes
3、buffer的默认值是20000bytes,可设置的最小值为2000bytes,最大值为1000000bytes

例子一、put和new_line	
set serveroutput on;
begin
   dbms_output.put('a'); --写入buffer但不输出
   dbms_output.put('b'); --写入buffer但不输出
   dbms_output.new_line; --回车(换行),输出                             
   dbms_output.put_line('hello world!'); --输出并换行
   dbms_output.put('d'); --写入buffer但不输出
end;                                                    
/ 

执行运行结果:	
ab
hello world!

例子二、put_line

	
set serveroutput off;
create table t(a int, b int, c int);
insert into t values(111111,222222,333333);
insert into t values(444444,555555,666666);
insert into t values(777777,888888,999999);
commit;
 
create table tt(a int,b varchar2(100));
 
declare
   msg varchar2(120);                              
   cursor t_cur is select * from t order by a;     
   v_line varchar2(100);                           
   v_status integer := 0;                          
begin                                           
   dbms_output.enable;                             
   for i in t_cur loop                             
       msg := i.a || ',' || i.b || ',' || i.c;         
       dbms_output.put_line(msg); --put                  
   end loop;                                      
                                                  
   dbms_output.get_line(v_line, v_status); --get         
   while v_status = 0 loop                        
       insert into tt values(v_status, v_line);       
       dbms_output.get_line(v_line, v_status);         
   end loop;                                      
end;                                           
/                                              
              
select * from tt;

执行结果如下:
	
a    b
--- -----------------------
0   111111,222222,333333
0   444444,555555,666666
0   777777,888888,999999

注:使用get_line时不能用put_line输出,因为put_line之后会将buffer清空。(当然在serveroutput off的情况下put_line是不影响buffer的)。

例子三:put_lines
	
set serveroutput on;
declare
   v_data dbms_output.chararr;                         
   v_numlines number;                                  
begin                                               
   --enable the buffer first.                         
   dbms_output.enable(1000000);                        
                                                      
   dbms_output.put_line('line one');                   
   dbms_output.put_line('line two');                   
   dbms_output.put_line('line three');                
                                                      
   v_numlines := 3;                                   
   dbms_output.get_lines(v_data, v_numlines);  --array, index       
   for v_counter in 1..v_numlines loop                
       dbms_output.put_line(v_data(v_counter));           
   end loop;                                          
end;                                               
/

执行结果如下:
	
line one
line two
line three

注意数组使用的格式。

转载于:https://www.cnblogs.com/Lightning-Kid/p/3862953.html

### PL/SQL 中通过 APEX_WEB_SERVICE 进行 REST 请求并与阿里云 API 交互 在 Oracle 数据库环境中,`APEX_WEB_SERVICE` 是个非常强大的工具包,用于发起 HTTP 或 HTTPS 请求。它允许开发者轻松实现与其他外部系统的集成,例如调用第三方 RESTful Web Service。 以下是关于如何使用 `APEX_WEB_SERVICE` 发起 REST 请求并与阿里云 API 交互的具体说明: #### 1. 准备工作 为了成功调用阿里云 API,需要完成以下准备工作: - 获取阿里云 API 的访问密钥(Access Key ID 和 Access Key Secret),这些信息通常可以在阿里云控制台的安全管理页面找到。 - 确定目标 API 的 URL 地址以及所需的参数列表。 - 如果涉及签名验证,则需按照阿里云官方文档中的签名算法生成请求签名[^4]。 #### 2. 创建必要的数据库对象 由于某些情况下可能需要用到自定义函数来计算哈希值或加密字符串,在正式编写调用逻辑之前,先确认已存在相应的辅助功能模块。如果没有现成可用的功能组件,则可以根据需求自行开发相应的过程或函数。 #### 3. 编写 PL/SQL 脚本执行 REST 请求 下面提供了个简单的例子演示如何利用 `APEX_WEB_SERVICE.MAKE_REST_REQUEST` 来向指定的目标地址发送 GET 类型的请求,并解析返回的结果集: ```sql DECLARE l_url VARCHAR2(32767); l_http_method VARCHAR2(10) := 'GET'; l_response_clob CLOB; BEGIN -- 构建完整的URL路径,包含所有必需参数 l_url := 'https://example-api.aliyun.com/api_endpoint?param1=value1&param2=value2'; -- 执行实际网络通信操作 l_response_clob := APEX_WEB_SERVICE.make_rest_request( p_url => l_url, p_http_method=> l_http_method); DBMS_OUTPUT.PUT_LINE(l_response_clob); END; ``` 上述代码片段展示了基本流程:设置好基础 URI 及其附加选项之后,借助于 `MAKE_REST_REQUEST()` 方法发出同步式的 HTTP 查询动作;最后读取出服务器端反馈的信息内容并通过标准输出设备展现出来。 对于 POST 请求或者其他更复杂的场景,比如上传文件、传递 JSON 格式的数据体等,则还需要额外配置更多属性项,如下所示: ```sql DECLARE l_url VARCHAR2(32767); l_payload CLOB; l_headers wwv_flow_t_varchar2; l_response_clob CLOB; BEGIN -- 定义负载数据结构 l_payload := '{"key":"value"}'; -- 初始化头部集合变量 l_headers.DELETE(); l_headers.extend; l_headers(l_headers.last).name :='Content-Type'; l_headers(l_headers.last).value :='application/json;charset=UTF-8'; -- 组合最终的服务定位符串 l_url := 'https://example-api.aliyun.com/api_endpoint'; -- 实施异步模式下的POST提交行为 l_response_clob := APEX_WEB_SERVICE.make_rest_request( p_url =>l_url , p_http_method =>'POST', p_body =>l_payload, p_wallet_path =>'file:/path/to/wallet/', p_wallet_pwd =>'password', p_transfer_timeout_seconds=>60, p_parm_name =>NULL, p_parm_value =>NULL, p_header_list =>l_headers ); dbms_output.put_line(l_response_clob); EXCEPTION WHEN OTHERS THEN raise_application_error(-20001,'An error was encountered - '||SQLCODE||' -ERROR-'||SQLERRM); END; ``` 此版本增加了几个新特性支持——特别是当涉及到安全性考量时(如 SSL/TLS 加密连接)、超时期限设定等方面都做了进步增强处理。 --- ### 注意事项 - **权限授予**:确保运行环境具备足够的权限去加载外部库资源和服务链接点。 - **错误捕获机制**:考虑到可能出现的各种异常状况,应该始终加入全面而细致化的异常捕捉分支语句块。 - **性能优化策略**:针对高并发量的应用场合下,考虑采用批量化作业调度方案减少重复性开销成本。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值