当前位置:首页 » 存储配置 » 查找存储过程

查找存储过程

发布时间: 2022-01-15 05:45:17

1. 怎样查找数据库中的所有存储过程

你的意思是
怎样查看创建
存储过程
的语句吗?
首先要知道
存储过程名称

sp_help
text
存储过程名
sp_helptext
视图名
sp_help
表名
sql
server
语句离执行就可以看到
还可以
找到该数据库
-可编译性-存储过程-找到存储过程名称-
右击
-修改
就可以查看了

2. 如何快速查找某个存储过程执行的状况

通过下面的SQL,我们可以快速查看某个存储过程执行的状况:
SELECT TOP 100 db_name(d.database_id) as DBName,s.name as 存储名称,s.type_desc as 存储类型,d.cached_time as SP添加到缓存的时间,
d.last_execution_time as 上次执行SP的时间,d.last_elapsed_time as [上次执行SP所用的时间(微妙)],d.total_elapsed_time as [完成此SP的执行所用的总时间(微妙)],
d.total_elapsed_time/d.execution_count as [平均执行时间(微妙)],d.execution_count as 自上次编译以来所执行的次数
FROM SYS.proceres S JOIN SYS.dm_exec_procere_stats D
ON S.object_id=D.object_id
WHERE S.NAME='SP_Name'
ORDER BY D.total_elapsed_time/D.execution_count DESC

3. 【SQL】如何查找指定存储过程名

可以用sql语句来查询, 像你的例子可以这样:select count(1) from sysobjects where name = "sp_a" and type = "P"
如果return 1 表示这个存储过程存在
如果你想查用户表也可以用上面的SQL,不过type = "U"
select count(1) from sysobjects where name = "table name" and type = "U"
希望对你有用

4. 存储过程 查询

第七章 存储过程(Procere)和包(Package)

SQLServer - 存储过程 (output参数 return)
Oracle -存储过程(out参数) 函数(return)

--1.存储过程
create or replace procere print(msg varchar2)
is
begin
dbms_output.put_line(msg);
end;

--1.1 调用存储过程
execute print('helloworld');

--1.2
create or replace procere findEmp(p_empno emp.empno%type)
is
v_ename emp.ename%type;
begin
select ename into v_ename
from emp where empno=p_empno;

print(v_ename);
exception
when no_data_found then
print('未发现指定员工.');
end;

--1.3 传递参数
create or replace procere myabs(p_num1 IN number,p_num2 OUT number)
is
begin
if p_num1 >0 then
p_num2 := p_num1;
else
p_num2 := (0 - p_num1);
end if;
end;

--调用
declare
v_result number;
begin
myabs(-987,v_result);
print(v_result);
end;

create or replace procere change_num(p_num1 IN OUT number,p_num2 IN OUT number)
is
v_temp number;
begin
v_temp := p_num1;
p_num1 := p_num2;
p_num2 := v_temp;
end;

--调用
declare
v_num1 number :=111;
v_num2 number :=222;
begin
change_num(v_num1,v_num2);

print(v_num1);
print(v_num2);
end;

--2.函数(FUNCTION)
create or replace function myabs1(p_num1 number)
return number
is
begin
if p_num1 >= 0 then
return p_num1;
else
return (0 - p_num1);
end if;
end;

begin
print(myabs1(-999));
end;

create or replace function findEmp1(p_empno emp.empno%type)
return emp.ename%type
is
v_ename emp.ename%type;
begin
select ename into v_ename
from emp
where empno=p_empno;

return v_ename;
exception
when no_data_found then
print('未发现员工');
end;

begin
print(findEmp1(7499));
end;

--3.包(Package)-包(package-定义)和包体(package body-实现)
create or replace package mypkg
is
procere print(msg varchar2);

function findEmp(p_empno number)
return emp.ename%type;
end;

create or replace package body mypkg
is
procere print(msg varchar2)
is
begin
dbms_output.put_line(msg);
end;

function findEmp(p_empno number)
return emp.ename%type
is
v_ename emp.ename%type;
begin
select ename into v_ename
from emp
where empno=p_empno;

return v_ename;
exception
when no_data_found then
print('未发现员工');
end;
end;

--4.通过函数返回结果集
create or replace function findAllEmps
return SYS_REFCURSOR
is
v_ref_cursor SYS_REFCURSOR;
begin
open v_ref_cursor
for 'select * from emp';

return v_ref_cursor;
end;

5. 知道存储过程名怎么查看存储过程代码

使用SQL Server Management Studio在列表中查看即可。

步骤:

1、登录SQL Server Management Studio。

2、左边的树点击要查询的库左边的“+”,点开后会变成“-”,下同。

6、如果是查看系统存储过程,在第3步后点击系统存储过程,然后找到要查的名字,同第4,5步即可。

6. 如何快速查找使用了某个字段的所有存储过程

当一个系统中使用了很多的表,并且存在大量的存储过程,当数据库中的某个表删除了某个字段,那么相应的存储过程也需要改动,但是我们不知道哪些存储过程使用了该字段,那我们该怎么办?我们可以从之前的文档一个一个查找使用了该字段的存储过程,但是这样效率很多,而且还容易出错,我们可以使用下面的方法来查找所有使用了某个字段的存储过程。如下的函数:


[sql] view plainprint?

01.GO

02.SELECT obj.Name 存储过程名, sc.TEXT 存储过程内容

03.FROM syscomments sc

04.INNER JOIN sysobjects obj ON sc.Id = obj.ID

05.WHERE sc.TEXT LIKE '%' + '字段名' + '%'

06.AND TYPE = 'P'

07.GO

GO

SELECT obj.Name 存储过程名, sc.TEXT 存储过程内容

FROM syscomments sc

INNER JOIN sysobjects obj ON sc.Id = obj.ID

WHERE sc.TEXT LIKE '%' + '字段名' + '%'

AND TYPE = 'P'

GO


下面举一个例子,比如查找数据库中所有使用了AdId这个字段的所有存储过程。



[sql] view plainprint?

01.USE KyCms

02.GO

03.SELECT obj.Name 存储过程名, sc.TEXT 存储过程内容

04.FROM syscomments sc

05.INNER JOIN sysobjects obj ON sc.Id = obj.ID

06.WHERE sc.TEXT LIKE '%' + 'AdID' + '%'

07.AND TYPE = 'P'

08.GO

USE KyCms

GO

SELECT obj.Name 存储过程名, sc.TEXT 存储过程内容

FROM syscomments sc

INNER JOIN sysobjects obj ON sc.Id = obj.ID

WHERE sc.TEXT LIKE '%' + 'AdID' + '%'

AND TYPE = 'P'

GO

7. 怎么查看一个存储过程的SQL语句

查看一个存储过程的SQL语句步骤如下:

1、开启Microsoft SQL Server数据库管理工具,输入账号密码连接到数据库。

8. 如何查询存储过程查询出来的结果

别建立 存储过程啊, 建立一个 表值函数 就行.

1> CREATE FUNCTION getHelloWorld()
2> RETURNS TABLE
3> AS
4> RETURN
5> SELECT 'Hello' AS A, 'World' AS B;
6> GO
1> SELECT * FROM getHelloWorld();
2> go
A B
----- -----
Hello World

(1 行受影响)

---

如果存储过程无法修改
那么需要查看 客户方 给出的 存储过程 的参数列表.
也就是 哪个参数是 IN 的, 哪个参数 是 OUT 的。
要 通过 调用存储过程的方式
拿到 OUT 参数对应的数据。

没法简单的 SELECT 了。

9. 如何使用sql语句查看存储过程

利用数据字典视图查看当前用户所有存储过程及其代码
select name,text from user_source where type='PROCEDURE'.

10. SQL 查找存储过程中出现过的文字怎么查询呢

在syscomments系统表里查,结合sysobjects系统表取得过程名

select b.name
from 数据库名.dbo.syscomments a,数据库名.dbo.sysobjects b where a.id=b.id and b.xtype='p' and a.text like '%insert into%'

“数据库名”替换成你实际的数据库名,因为每个数据库里的存储过程都是单独保存在自己数据库的syscomments表内,所以要加上数据库名,这样就不用在切换数据库上下文了。另外加密的存储过程是查不出来的。

热点内容
intel快速存储ssd 发布:2024-11-15 20:00:27 浏览:142
吃鸡配置太低怎么调高画质 发布:2024-11-15 19:58:19 浏览:734
王者怎么设置来电屏蔽安卓 发布:2024-11-15 19:56:08 浏览:449
服务器如何搭建多个ip 发布:2024-11-15 19:42:10 浏览:102
价钱低高配置的有哪些车 发布:2024-11-15 19:34:53 浏览:380
androidgps定位开发 发布:2024-11-15 19:34:52 浏览:334
如何扫码添加服务器地址 发布:2024-11-15 19:31:48 浏览:278
sql语句复制数据库 发布:2024-11-15 19:28:02 浏览:837
算法的薪资 发布:2024-11-15 19:15:22 浏览:322
ubuntu可以重新编译吗 发布:2024-11-15 19:09:10 浏览:649