1.ORACLE 索引及性能相关系统视图使用2.ORACLE闪回功能基本用法3.【检查ORACLE阻塞】如果阻塞超过N秒则发短信报警并KILL进程4.如何批量脚本停用(启用)SQL Server 和 ORACLE 数据库用户作业5.ORACLE隔离级别与脏读/不可重复读/幻读的关系以及SELECT FOR UPDATE用法6.ORACLE 中 START WITH CONNECT BY PRIOR 用法(用于父子关系的数据表查询)7.ORACLE / SQL Server-查询最终阻塞者进程脚本8.关于Oracle客户端运行SQLPlus.exe9.SQL SERVER / ORACLE 拼接多行记录字段为一个字符串的方法10.ORACLE自定义函数返回记录集(表类型)的写法11.【转】Oracle 建立索引及SQL优化12.【ORACLE】调整序列的当前种子值13.ORACLE 检索某列包含特定字符串的数据表工具存储过程14.ORACLE常用修改字段脚本15.在oracle中怎么通过字段名查询其所在的表16.ORACLE 查询所有用户调度作业17.【ORACLE】查看死锁进程并结束死锁的脚本18.Oracle获取最近执行的SQL语句19.Oracle的函数返回表类型(转)20.ORACLE变量定义及使用(另,T-SQL EXISTS的PLSQL替代写法)21.ORACLE常用脚本示例22.使用 PL/SQL Developer Version 14 调试 Oracle 存储过程
23.Oracle前端工具(PL/SQL Developer)—在不安装Oracle客户端的情况下使用
24.SQL SERVER/ORACLE 将ID串列转换为多行的写法25.ORACLE 游标和NULLIF函数在触发器中的使用26.关于“LINQ to Entities does not recognize the Method '...' ”问题原因浅析27.Oracle作业执行与SQL Develop运行语句(脚本)的区别28.ORACLE 创建表前判断是否已存在29.ORACLE 返回类型为SYS_REFCURSOR的存储过程用法30.ORACLE杂文之自定义函数与随机函数Oracle—在不安装oracle客户端的情况下,使用PL/SQL Developer 14
在使用plsql时,需要指定OCI.DLL文件,这就需要安装oracle客户端,不过oracle客户端软件有点庞大,推荐使用下面方法不依赖oracle客户端来使用plsql。
1、准备
虽然不用oracle客户端,但是也要用到一个工具包--instantclient,可以到oracle官网下载(视具体操作系统版本下载对应文件):
2、下载完毕文件名为 instantclient-basic-windows.x64-21.6.0.0.0dbru.zip
3、解压到你自己指定的路径(如C:\Users\11513\Oracle),那么主目录就是 C:\Users\11513\Oracle\instantclient_21_6
4、创建在C:\Users\11513\Oracle\instantclient_21_6\network\admin路径下创建文件tnsnames.ora,内容如下:
# tnsnames.ora Network Configuration File: f:\app\guoshaoyue\product\11.2.0\client_1\NETWORK\ADMIN\tnsnames.ora
# Generated by Oracle configuration tools.
ZSYKTEST =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 172.18.133.194)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = ZSYKTEST)
)
)
|
5、配置PL/SQL
依次打开“tools--preferences--connection”,配置:
Oracle Home(Oracle主目录):C:\Users\11513\Oracle\instantclient_21_6
OCI library(OCI库):C:\Users\11513\Oracle\instantclient_21_6\oci.dll


6、PL/SQL的SQL窗口执行代码段,注意一定要以 “/” 结尾,否则啥也不会输出:
--set serveroutput on;
declare
v_code number;
v_ret varchar(200);
begin
-- Call the procedure
prpa.PGETREPORTMSG(V_IN_CardType =>'1',
V_IN_CardNo=> 'K093',
V_OUT_RETCODE=> v_code,
V_OUT_RETMSG=> v_ret);
DBMS_OUTPUT.PUT_LINE('V_OUT_RETCODE ="' ||v_code || '"');
DBMS_OUTPUT.PUT_LINE('V_OUT_RETMSG ="' || v_ret|| '"');
end;
/
6、PL/SQL的命令窗口执行代码段,注意一定也要以 “/” 结尾(包括执行SQL文件),否则啥也不会输出:
Connected to Oracle Database 19c Enterprise Edition Release 19.0.0.0.0
Connected as apps@172.18.133.194:1521/ZSYKTEST
SQL>
SQL> declare
2 v_code number;
3 v_ret varchar(200);
4 begin
5 -- Call the procedure
6 prpa.PGETREPORTMSG(V_IN_CardType => '1',
7 V_IN_CardNo => 'K093',
8 V_OUT_RETCODE => v_code,
9 V_OUT_RETMSG => v_ret);
10 DBMS_OUTPUT.PUT_LINE('V_OUT_RETCODE = "' || v_code || '"');
11 DBMS_OUTPUT.PUT_LINE('V_OUT_RETMSG = "' || v_ret || '"');
12 end;
13 /
V_OUT_RETCODE = "5"
V_OUT_RETMSG = " 您的预约报到开始时间为11:30,请于开始后报到。"
PL/SQL procedure successfully completed
SQL>
|
Connected to Oracle Database 19c Enterprise Edition Release 19.0.0.0.0
Connected as apps@172.18.133.194:1521/ZSYKTEST
SQL> @F:\plsqldoc\test.sql
V_OUT_RETCODE = "5"
V_OUT_RETMSG = " 您的预约报到开始时间为11:30,请于开始后报到。"
PL/SQL procedure successfully completed
SQL>
|
F:\plsqldoc\test.sql文件的内容:
--set serveroutput on;
declare
v_code number;
v_ret varchar(200);
begin
-- Call the procedure
prpa.PGETREPORTMSG(V_IN_CardType =>'1',
V_IN_CardNo=> 'K093',
V_OUT_RETCODE=> v_code,
V_OUT_RETMSG=> v_ret);
DBMS_OUTPUT.PUT_LINE('V_OUT_RETCODE ="' ||v_code || '"');
DBMS_OUTPUT.PUT_LINE('V_OUT_RETMSG ="' || v_ret|| '"');
end;
/
合集:
ORACLE
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 实操Deepseek接入个人知识库
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
2015-09-22 获取资源字典的控件模板的控件实例方法
2011-09-22 WCF与SilverLight Web不在同一站点时部署域访问策略xml文件的注意事项