- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
很多年前我曾经做过Oracle开发。过去 15 年的大部分时间我主要从事 SQL Server 工作,并从事 Oracle 工作,与 Web 服务等工作隔离。
我的问题似乎在网上被问过几次,但似乎很难沟通 - 至少从答案来看。我非常欣赏工具和功能的不同,知道我必须学习新东西,但这是如此简单,但似乎很难做到。
我希望对数据库进行一些临时查询。目前我们正在使用 SQL Navigator - 我愿意使用其他工具...
在 SQL Server Management Studio 中,如果打开查询窗口,键入一些返回值或集合的 SQL,您将在结果窗口中获得行或值的良好显示。
我发现 Oracle PL/SQL 的情况有点不同,我发现我需要返回一个游标 - 但如何获得一个工具来显示结果?
我开始很简单:
declare
my_id number := 356655;
cursor c1 is select my_id from dual;
begin
open c1;
end;
运行良好 - 但我如何查看结果?有没有像 SSMS 一样“很好”地处理这个问题的工具?我已经习惯了能够做很多这样的事情,包括诸如此类的事情
(也许语法不完全正确?但你明白了......)
declare
my_id number := 356655;
cursor c1 is select name from my_table where id = my_id;
begin
open c1;
并将结果以文本/网格形式显示给我。理想情况下,有一个很好的解决方案。也许是一些漂亮的新工具?
最佳答案
与 SQL Developer或者 SQL*Plus,您可以使用在 PL/SQL block 之前声明的绑定(bind)变量:
variable rc refcursor;
declare
my_id number := 356655;
begin
open :rc for select my_id from dual;
end;
/
print rc
RC
-------------------------------
356655
您还可以在查询中使用绑定(bind)变量,这很有用:
variable my_id number;
variable rc refcursor;
execute :my_id := 356655;
begin
open :rc for select :my_id from dual;
end;
/
print rc
variable
和 print
SQL*Plus 文档中涵盖了命令,该文档很大程度上也适用于 SQL Developer - 其 own documentation ,包括commands that are carried over from SQL*Plus .
如果您有一个返回引用游标的函数,那么您可以在查询中调用该函数,如select func(val) from Dual
,然后结果可以放入网格中;或者您可以使用相同的 :rc
绑定(bind)变量调用函数(或过程)并打印它。但如果您只进行临时查询,我不确定这两者是否有帮助。
另一方面,即使您的查询很复杂,使用 PL/SQL block 进行即席查询似乎有点粗暴。您需要一个充分的理由来为 block 内的 select 语句打开游标,而不是直接运行 select
。 (不确定这是否是 SQL Server 的问题,或者您是否确实需要这样做!)。如果您只是在 block 内运行查询,则不需要该 block ,即使您想为查询中使用的值保留绑定(bind)变量:
variable my_id number;
execute :my_id := 356655;
select :my_id from dual;
:MY_ID
----------
356655
关于sql - 即席查询 Oracle PL/SQL - 面向 SQL Server 开发人员,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22758763/
是否有用于手动测试的代码覆盖工具?比如我新写了30行代码,编译,然后运行,有什么办法可以快速验证这30行都运行了吗? 另外,后来,在我将代码 checkin 正式版本后,有什么方法可以验证测试部门在进
老实说,这是一个家庭作业问题,但我已经浪费了好几个小时,而且无法正确解决。它返回错误数量的结果或错误的数据: 我需要选择参与指导电影和/或在电影中表演的每个人以及他们所做的次数,如果至少 5 次。 有
我正在尝试测试 MacOS 的应用内购买。输入测试用户凭据后,App Store 提示:“当前收据无效或 ds 人员 ID 不匹配。”并且购买失败。 最佳答案 我尝试了很多方法来解决这个问题。 Get
我正在为 Jenkins 使用 ActiveDirectory 插件,因此用户必须使用他们的凭据登录到 Jenkins。然后用户在 Jenkins 中被称为 joe.doe,这很完美。 当同一个人 c
如何从 Infopath 人员/组选取器检索电子邮件地址?当我将人员/组选取器添加到 infopath 表单时,我只得到 3 个字段 DisplayName、AccountId、AccountType
在 Snow Leopard 中,可以在 iCal 事件中显示空闲/忙碌时间。我搜索了 CalStore.framework 的 header ,但找不到任何描述该字段的属性。如何检索日历事件的忙/闲
是否有人成功地从专门针对 SharePoint 2013 的新建或编辑表单中获取用户(个人或组)字段的值? 我已经尝试了通过搜索互联网找到的所有解决方案以及我自己能想到的所有解决方案,所有结果都为空白
所以我需要将一个 Twitter 帐户添加到 ABRecordRef 中。然而,最快的方法似乎是获取社交资料属性的多值引用,创建它的可变版本,查找它是否有 Twitter 条目,如果已经有,则创建
我正在尝试将使用 Tomcat(最初是 5.5,但可以与 7 一起使用)在 MyEclipse 中开发的应用程序部署到我们的演示服务器 (Sun Java Web Server 7)。不幸的是,所有设
我是一名优秀的程序员,十分优秀!