當前位置:首頁 » 服務存儲 » 存儲過程中的頻率
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

存儲過程中的頻率

發布時間: 2023-07-03 04:21:03

Ⅰ mysql 與oracle中的存儲過程及函數有什麼區別,盡可能詳細哦

本質上沒區別。只是函數有如:只能返回一個變數的限制。而存儲過程可以返回多個。而函數是可以嵌入在sql中使用的,可以在select中調用,而存儲過程不行。執行的本質都一樣。
函數限制比較多,比如不能用臨時表,只能用表變數.還有一些函數都不可用等等.而存儲過程的限制相對就比較少
由於我現在基本上是DBA的工作,因此平時也看一些資料庫方面的書籍。但是我一直對存儲過程和函數之間的區別掌握不透。我向來認為存儲過程可以實現的操作,函數也一樣可以實現。最近,剛好大學的老師給我們上SQL-Server的課程,我對這個問題的疑惑終於慢慢解開。今天晚上順便看了些網上的資料,覺得以下分析比較合理:
1. 一般來說,存儲過程實現的功能要復雜一點,而函數的實現的功能針對性比較強。
2. 對於存儲過程來說可以返回參數,而函數只能返回值或者表對象。
3. 存儲過程一般是作為一個獨立的部分來執行,而函數可以作為查詢語句的一個部分來調用,由於函數可以返回一個表對象,因此它可以在查詢語句中位於FROM關鍵字的後面。
4. 當存儲過程和函數被執行的時候,SQL Manager會到procere cache中去取相應的查詢語句,如果在procere cache里沒有相應的查詢語句,SQL Manager就會對存儲過程和函數進行編譯。
Procere cache中保存的是執行計劃 (execution plan) ,當編譯好之後就執行procere cache中的execution plan,之後SQL SERVER會根據每個execution plan的實際情況來考慮是否要在cache中保存這個plan,評判的標准一個是這個execution plan可能被使用的頻率;其次是生成這個plan的代價,也就是編譯的耗時。保存在cache中的plan在下次執行時就不用再編譯了。
存儲過程和用戶自定義函數具體的區別
存儲過程
存儲過程可以使得對資料庫的管理、以及顯示關於資料庫及其用戶信息的工作容易得多。存儲過程是 SQL 語句和可選控制流語句的預編譯集合,以一個名稱存儲並作為一個單元處理。存儲過程存儲在資料庫內,可由應用程序通過一個調用執行,而且允許用戶聲明變數、有條件執行以及其它強大的編程功能。
存儲過程可包含程序流、邏輯以及對資料庫的查詢。它們可以接受參數、輸出參數、返回單個或多個結果集以及返回值。
可以出於任何使用 SQL 語句的目的來使用存儲過程,它具有以下優點:
可以在單個存儲過程中執行一系列 SQL 語句。
可以從自己的存儲過程內引用其它存儲過程,這可以簡化一系列復雜語句。
存儲過程在創建時即在伺服器上進行編譯,所以執行起來比單個 SQL 語句快。
用戶定義函數
函數是由一個或多個 Transact-SQL 語句組成的子程序,可用於封裝代碼以便重新使用。Microsoft? SQL Server? 2000 並不將用戶限制在定義為 Transact-SQL 語言一部分的內置函數上,而是允許用戶創建自己的用戶定義函數。
可使用 CREATE FUNCTION 語句創建、使用 ALTER FUNCTION 語句修改、以及使用 DROP FUNCTION 語句除去用戶定義函數。每個完全合法的用戶定義函數名 (database_name.owner_name.function_name) 必須唯一。
必須被授予 CREATE FUNCTION 許可權才能創建、修改或除去用戶定義函數。不是所有者的用戶在 Transact-SQL 語句中使用某個函數之前,必須先給此用戶授予該函數的適當許可權。若要創建或更改在 CHECK 約束、DEFAULT 子句或計算列定義中引用用戶定義函數的表,還必須具有函數的 REFERENCES 許可權。
函數中的有效語句類型包括:
DECLARE 語句,該語句可用於定義函數局部的數據變數和游標。
為函數局部對象賦值,如使用 SET 給標量和表局部變數賦值。
游標操作,該操作引用在函數中聲明、打開、關閉和釋放的局部游標。不允許使用 FETCH 語句將數據返回到客戶端。僅允許使用 FETCH 語句通過 INTO 子句給局部變數賦值。
控制流語句。
SELECT 語句,該語句包含帶有表達式的選擇列表,其中的表達式將值賦予函數的局部變數。
INSERT、UPDATE 和 DELETE 語句,這些語句修改函數的局部 table 變數。
EXECUTE 語句,該語句調用擴展存儲過程。
在查詢中指定的函數的實際執行次數在優化器生成的執行計劃間可能不同。示例為 WHERE 子句中的子查詢喚醒調用的函數。子查詢及其函數執行的次數會因優化器選擇的訪問路徑而異

Ⅱ SqlServer如何設置每秒執行存儲過程

  • 打開SQL Server Management Studio,SQL Server代理--作業--點右鍵--新建作業

  • 作業的名稱取為:test

    並進行說明,若作業的數量太多,以方便區別;

    這里寫上定時執行存儲過程Pr_test

    確定保存.

  • 點擊常規下面的步驟,按箭頭指示,新建步驟.

  • 取名步驟名稱:exec pr_test

    注意選擇存儲過程所在的資料庫

    錄入需要執行的命令:exec pr_test ,確定保存.

    若有其它參數命令也可以編寫

  • 接下來設置計劃,自動定時執行的時間.

    新建計劃,進放計劃屬性設置窗口.

  • 6

    依然要填寫計劃的名稱:exec pr_test

    計劃類型:重復計劃

    時間頻率:每月的26日的12點30分自動執行一次

    持續時間:無結束日期

    確定保存.到此基本功能已經設置完成,額外其它功能可以根據需要進行增加.

Ⅲ 資料庫存儲過程是什麼

問題一:sql資料庫中的存儲過程該怎麼理解 有什麼用啊? 存儲過程是SQL 語句和流程式控制制語句的預編譯 *** ,以一個名稱存儲並作為一個單元處理。存儲過程存儲在資料庫內,可由應用程序調用執行,而且允許用戶聲明變數、有條件執行以及其它強大的編程功能。

問題二:資料庫中什麼是存儲過程?作用是什麼? 存儲過程,就是帶有名字的一個程序塊。
存儲,是指這個程序塊創建了之後,是存儲在資料庫內部的,然後我們可以在自己寫的程序中通過某種手段去調用這段程序,然後這段程序就會做一件事,做什麼事?我們定義存儲過程的時候怎麼寫的,它到時候就做什麼;
過程,就是程序塊,說白了就是一段程序。
存儲過程,創建完成之後,就存儲在資料庫內部了,資料庫幫你記著,存儲過程創建的時候都有一個名字,將來你在你的程序當中,通過某種方式(不同編程語言有不同的方式),一般來講通過這個名字,去調用存儲過程,就像使用一個方法或者函數一樣,它就去做一件事!
不同的資料庫的存儲過程,都是用當前自己這個資料庫的編程語言來編寫的,比如Oracle的PL/SQL編程,等等。
自己寫一個就明白了,語法不用我多說了吧?

問題三:什麼叫作資料庫的存儲過程? 存儲過程就是將常用的或很復雜的工作,預先用SQL語句寫好並用一個指定的名稱存儲起來,並且這樣的語句是放在資料庫中的,還可以根據條件執行不同SQL語句, 那麼以後要叫資料庫提供與已定義好的存儲過程的功能相同的服務時,只需調用execute,即可自動完成命令。 存儲過程的優點 1.存儲過程只在創造時進行編譯即可,以後每次執行存儲過程都不需再重新編譯,而我們通常使用的SQL語句每執行一次就編譯一次,所以使用存儲過程可提高資料庫執行速度。 2.經常會遇到復雜的業務邏輯和對資料庫的操作,這個時候就會用SP來封裝資料庫操作。當對資料庫進行復雜操作時(如對多個表進行Update,Insert,Query,Delete時),可將此復雜操作用存儲過程封裝起來與資料庫提供的事務處理結合一起使用。可以極大的提高資料庫的使用效率,減少程序的執行時間,這一點在較大數據量的資料庫的操作中是非常重要的。在代碼上看,SQL語句和程序代碼語句的分離,可以提高程序代碼的可讀性。 3.存儲過程可以設置參數,可以根據傳入參數的不同重復使用同一個存儲過程,從而高效的提高代碼的優化率和可讀性。 4.安全性高,可設定只有某此用戶才具有對指定存儲過程的使用權存儲過程的種類: (1)系統存儲過程:以sp_開頭,用來進行系統的各項設定.取得信息.相關管理工作,如 sp_help就是取得指定對象的相關信息。 (2)擴展存儲過程 以XP_開頭,用來調用操作系統提供的功能exec master..xp_cmdshell 'ping 10.8.16.1' (3)用戶自定義的存儲過程,這是我們所指的存儲過程常用格式 模版:Create procere procee_name [@parameter data_type][output][with]{repile|encryption} as sql_statement 解釋:output:表示此參數是可傳回的 with {repile|encryption} repile:表示每次執行此存儲過程時都重新編譯一次;encryption:所創建的存儲過程的內容會被加密。

問題四:資料庫中存儲過程有什麼主要作用,或都說它的主要用途? 存儲過程的概念
存儲過程(Stored Procere)是一組預先編繹好的Transact-SQL語句。將其放在伺服器上,由用戶通過指定存儲過程的名字來執行它。存儲過程可以作為一個獨立的資料庫對象,也可以作為一個單元被用戶的應用程序調用。存儲過程可以接收和輸出參數,返回執行存儲過程的狀態值,還可以嵌套調用。
存儲過程同其他編程語言中的過程(Procere)類似,主要體現在以下幾個方面:
(1)存儲過程可以接收參數,並以接收參數的形式返回多個參數給調用存儲過程和批處理。
(2)包含執行資料庫操作的編程語句,也可以調用其他的存儲過程。
(3)向調用過程或批處理返回狀態值,以反映存儲過程的執行情況。
注意:存儲過程跟函數不同,存儲過程不能在被調用的位置上返回數據,也不能被應用在語句當中,例如不可以用類似「@Proc=存儲過程名」的方式使用存儲過程。但是,存儲過程可以使用變數的形式來返回參數。
存儲過程的優點表現在以下幾個方面:
(1)執行速度快
存儲過程在創建時就經過了語法檢查和性能優化,因此在執行時不必再重復這些步驟。存儲過程在第一次調用後,就駐留在內存中,不必再經過編譯和優化,所以執行速度很快。在有大量批處理的Transact-SQL語句要重復執行的時候,使用存儲過程可以極大地提高運行效率。
(2)模塊化程序設計
只需創建存儲過程一次,並將其存儲在資料庫中,可以在程序中多次調用該存儲過程。用戶可以獨立於應用程序而對存儲過程進行修改。
(3)減少網路通信量
存儲過程中可以包含大量的Transact-SQL語句。在進行調用時,只需要使用一條語句就可以實現,而不需要在網路中發送數百行代碼。
(4)保證系統的安全性
可以設置用戶通過存儲過程來對某些關鍵數據進行訪問,但不允許用戶直接使用Transact-SQL語句或企業管理器來對數據進行訪問。

問題五:資料庫存儲過程和函數的區別 函數分兩種,表值函數跟標量函數
表值函數最後要返回一個表變數,而標量函數最後要返回一個標量值
存儲過程即一組批處理,可以返回或不返回值,僅僅是執行其內部的全部語句
函數可以與一般sql語句一同編寫,而存儲過程不可以,需要單獨執行

問題六:資料庫編輯存儲過程是什麼意思 一般來說,程序員都希望編寫出來的程序能有最大化的應變能力,存儲過程的最大作用是可以降低代碼維護的工作量,很多需求的變化不用修改代碼進而發布程序,而只需要調整一下存儲過程即可實現
例如你打算開發一個報表,該報表會對資料庫的數據進行一定程度的加工,然後再呈現給用戶,那麼你的實現方法有兩個
1. 使用代碼調用SQL,取到基礎數據後,在程序代盯裡面進行加工,並呈現給用戶
2. 也可以編寫一段存儲過程,該存儲過程先取基礎數據,然後在存儲過程裡面進行數據加工,最後把最終的結果一次性的反饋給程序代碼,程序代碼只需要把執行完存儲過程的結果呈現給用戶即可
這兩個方法都可以實現你想實現的功能,但是如果萬一有一天需求變化了,用戶需要呈現的結果中增加或者減少了部分內容,那麼第一個方法就只能修改代碼了,而第二個方法只需要調整存儲過程即可實現

問題七:在SQL中存儲過程的一般語法是什麼? sql server存儲過程語法
存儲過程就是作為可執行對象存放在資料庫中的一個或多個SQL命令。
定義總是很抽象。存儲過程其實就是能完成一定操作的一組SQL語句,只不過這組語句是放在資料庫中的(這里我們只談SQL Server)。如果我們通過創建存儲過程以及在ASP中調用存儲過程,就可以避免將SQL語句同ASP代碼混雜在一起。這樣做的好處至少有三個:
第一、大大提高效率。存儲過程本身的執行速度非常快,而且,調用存儲過程可以大大減少同資料庫的交互次數。
第二、提高安全性。假如將SQL語句混合在ASP代碼中,一旦代碼失密,同時也就意味著庫結構失密。
第三、有利於SQL語句的重用。

在ASP中,一般通過mand對象調用存儲過程,根據不同情況,本文也介紹其它調用方法。為了方便說明,根據存儲過程的輸入輸出,作以下簡單分類:
1. 只返回單一記錄集的存儲過程
假設有以下存儲過程(本文的目的不在於講述T-SQL語法,所以存儲過程只給出代碼,不作說明):
/*SP1*/
CREATE PROCEDURE dbo.getUserList
as
set nocount on
begin
select * from dbo.[userinfo]
end
go
以上存儲過程取得userinfo表中的所有記錄,返回一個記錄集。通過mand對象調用該存儲過程的ASP代碼如下:

'**通過mand對象調用存儲過程**
DIM Mym,MyRst
Set Mym = Server.CreateObject(ADODB.mand)
Mym.ActiveConnection = MyConStr 'MyConStr是資料庫連接字串
Mym.mandText = getUserList '指定存儲過程名
Mym.mandType = 4 '表明這是一個存儲過程
Mym.Prepared = true '要求將SQL命令先行編譯
Set MyRst = Mym.Execute
Set Mym = Nothing
存儲嘩程取得的記錄集賦給MyRst,接下來,可以對MyRst進行操作。
在以上代碼中,mandType屬性表明請求的類型,取值及說明如下:
-1 表明mandText參數的類型無法確定
1 表明mandText是一般的命令類型
2 表明mandText參數是一個存在的表名稱
4 表明mandText參數是一個存儲過程的名稱

還可以通過Connection對象或Recordset對象調用存儲過程,方法分別如下:
'**通過Connection對象調用存儲過程**
DIM MyConn,MyRst
Set MyConn = Server.CreateObject(&qu......>>

問題八:T-SQL和存儲過程有什麼區別 20分 區別T-SQL是語言,存儲過程是資料庫一種對象
T-SQL 即 Transact-SQL,是 SQL 在 Microsoft SQL Server 上的增強版,它是用來讓應用程式與 SQL Server 溝通的主要語言。
Transact-SQL中的存儲過程,非常類似於Java語言中的方法,它可以重復調用。當存儲過程執行一次後,可以將語句緩存中,這樣下次執行的時候直接使用緩存中的語句。這樣就可以提高存儲過程的性能。
? 存儲過程的概念
存儲過程Procere是一組為了完成特定功能的SQL語句 *** ,經編譯後存儲在資料庫中,用戶通過指定存儲過程的名稱並給出參數來執行。
存儲過程中可以包含邏輯控制語句和數據操縱語句,它可以接受參數、輸出參數、返回單個或多個結果集以及返回值。
由於存儲過程在創建時即在資料庫伺服器上進行了編譯並存儲在資料庫中,所以存儲過程運行要比單個的SQL語句塊要快。同時由於在調用時只需用提供存儲過程名和必要的參數信息,所以在一定程度上也可以減少網路流量、簡單網路負擔。

問題九:資料庫存儲過程怎麼調用存儲過程 在存儲過程里用exec執行另一存儲過程名及它需要的參數就可以了
如 exec abc '1', '2' (abc 是存儲過程的名字, '1','2' 是它的參數)

Ⅳ 用sql查詢資料庫的欄位頻率

我猜想你是帶參數的查詢資料庫里的數據吧!
protected void Page_Load(object sender, EventArgs e)
{

}
protected void Button1_Click(object sender, EventArgs e)
{
string stt = "select manager_name,manager_pwd,department_id from manager where manager_name='" + TextBox1.Text + "' and manager_pwd='" + TextBox2.Text + "' and department_id='"+DropDownList1.SelectedValue+"'";
SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["aaaaaaConnectionString"].ToString());
conn.Open();
SqlCommand cmd = new SqlCommand(stt,conn);
SqlDataReader sdr = cmd.ExecuteReader();

if (sdr.Read())
{
Response.Redirect("default.aspx");
}
else
{
Response.Redirect("login.aspx");
}
sdr.Close();
conn.Close();
}

以上是一個登陸代碼,或許可以給你參考一下!

public SqlDataReader GetUserLoginByProc(string sUserName, string sPassword)
{
SqlConnection con = DB.createDB();
SqlCommand cmd = new SqlCommand("Pr_GetUserLogin",con);
//設置為執行存儲過程
cmd.CommandType = CommandType.StoredProcere;
//添加存儲過程參數
SqlParameter pUserName = new SqlParameter("@UserName",SqlDbType.VarChar,50);
pUserName.Value = sUserName.text;
cmd.Parameters.Add(pUserName);
SqlParameter pPassword = new SqlParameter("@Password",SqlDbType.VarChar,100);
pPassword.Value = sPassword.text;
cmd.Parameters.Add(pPassword);
SqlDataReader dr = null;
try
{
con.Open();
dr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
}
catch (SqlException ex)
{
throw new Exception(ex.Message,ex);
}
return dr;
}
存儲過程如下:
create proc select_user_login
@userName varchar(50),//可以為輸出參數,後加 output
@userPwd varchar(100)
as
select userName,userPassword
from arc_user
where userName=@userName and userPassword=@userPwd
go

Ⅳ 存儲過程應用語句有哪些

存儲過程與其他面向對象的程序設計語言一樣,同樣包含數據類型、流程式控制制、語句注釋、輸入和輸出與自己的函數庫。存儲過程的流程式控制制語句有ifelse、casewhenthen、while等,但沒有for循環,跟C++、Java等語言的流程式控制制語句非常類似。條件語句條件語句是流程式控制制的重要組成部分,跟其他編程語言一樣,存儲過程允許使用if關鍵字來作條件判斷,除此之外,還可以使用case來實現其他更為靈活的條件控制。

1.if語句(1)if語法if語句是最普通的條件控制語句,其語法簡單易懂,在存儲過程代碼中隨處可見,也是使用頻率最高的條件判斷語句。

語法格式:if…then…elseif…then…else…endif其中,((1)if後面跟判斷條件;

(2)elseif後面跟判斷條件;

(3)then後面跟條件分支語句塊;

(4)可以有多個elseif…then語句塊,也可以沒有;(5)else表示以上條件均不滿足時會執行的語句塊;

(6)整個條件語句塊的最後面以endif表示結束。if語句的用法,以語句「ifcondition_para=1then」開始條件控制,以語句「endif」結束條件控制,中間用「elseif」「else」作條件分支控制。單個SQL語句if語法語句格式:if(expr1