當前位置:首頁 » 存儲配置 » 查找存儲過程

查找存儲過程

發布時間: 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表內,所以要加上資料庫名,這樣就不用在切換資料庫上下文了。另外加密的存儲過程是查不出來的。

熱點內容
vb軟體加密 發布:2024-11-15 21:17:23 瀏覽:595
本地ip可以搭伺服器嗎 發布:2024-11-15 21:04:27 瀏覽:162
阿里巴巴python 發布:2024-11-15 20:56:25 瀏覽:782
博圖腳本編輯 發布:2024-11-15 20:41:06 瀏覽:312
帶密碼的箱子鑰匙在哪裡 發布:2024-11-15 20:40:12 瀏覽:236
兩個次梁相交怎麼配置 發布:2024-11-15 20:27:35 瀏覽:373
android關機實現 發布:2024-11-15 20:26:42 瀏覽:56
木糠壓縮原理 發布:2024-11-15 20:22:53 瀏覽:654
編譯原理難以理解的問題 發布:2024-11-15 20:11:25 瀏覽:130
安卓9是什麼水平 發布:2024-11-15 20:06:57 瀏覽:185