sql存儲過程超時-ag真人国际官网
多長都有可能,40是很正常的。
1.盡量優化語句,盡量少用游標。
2.修改較為常用的表要注意,最好先在臨時表中作好運算和其它處理,最後在修改這些表,以免較慢的存儲過程長時間鎖定表記錄,影響數據正常使用。
3.將連接超時和命令超時適當擴大,以免超時錯誤。
b. oracle存儲過程sql執行超時
oracle存儲過程sql執行超時要優化系統。優化系統步驟:
1、參數默認是30秒,執行的sql超過30秒就會報超時錯誤。
2、優化sql讓執行更快。
3、修改這個參數,在調用執行sql語句之前。oracle公司(甲骨文)是全球最大的信息管理軟體及服務供應商,成立於1977年,總部位於美國加州redwoodshore,面向全球開放oracle認證,oracle開發的關系資料庫產品因性能卓越而聞名,oracle資料庫產品為財富排行榜上的前1000家公司所採用。
c. sql server 存儲過程
在執行存儲過程時,我們常遇到執行超時的情況。如果是因為要處理的數據過多,修改流程復雜等原因的話,如以用以下方法解決:在存儲過程的處理工作中加上事務管理:set transaction isolation level repeatable read --->要這行
begin tran /* 這里是程序處理代碼段*/commit transaction
quitwithrollback:
if (@@trancount > 0)
begin
rollback transaction
end 以下是事務相關的知識:begin transaction--開始事務declare @errorsun int --定義錯誤計數器set @errorsun=0 --沒錯為0update a set id=232 where a=1 --事務操作sql語句set @errorsun=@errorsun @@error --累計是否有錯update aa set id=2 where a=1 --事務操作sql語句set @errorsun=@errorsun @@error --累計是否有錯if @errorsun<>0 begin print '有錯誤,回滾'rollback transaction--事務回滾語句end else begin print '成功,提交'commit transaction--事務提交語句end1.什麼是事務:事務是一個不可分割的工作邏輯單元,在資料庫系統上執行並發操作時事務是做為最小的控制單元來使用的。他包含的所有資料庫操作命令作為一個整體一起向系提交或撤消,這一組資料庫操作命令要麼都執行,要麼都不執行。2.事務的語句開始事物:begin transaction 提交事物:commit transaction 回滾事務:rollback transaction3.事務的4個屬性①原子性(atomicity):事務中的所有元素作為一個整體提交或回滾,事務的個元素是不可分的,事務是一個完整操作。②一致性(consistemcy):事物完成時,數據必須是一致的,也就是說,和事物開始之前,數據存儲中的數據處於一致狀態。保證數據的無損。③隔離性(isolation):對數據進行修改的多個事務是彼此隔離的。這表明事務必須是獨立的,不應該以任何方式以來於或影響其他事務。④持久性(durability):事務完成之後,它對於系統的影響是永久的,該修改即使出現系統故障也將一直保留,真實的修改了資料庫4.事務的保存點 save transaction 保存點名稱 --自定義保存點的名稱和位置 rollback transaction 保存點名稱 --回滾到自定義的保存點 二事例 所謂事務是指一組邏輯操作單元,它使數據從一種狀態變換到另一種狀態。包括四個特性:1、原子性 就是事務應作為一個工作單元,事務處理完成,所有的工作要麼都在資料庫中保存下來,要麼完全回滾,全部不保留2、一致性 事務完成或者撤銷後,都應該處於一致的狀態3、隔離性 多個事務同時進行,它們之間應該互不幹擾.應該防止一個事務處理其他事務也要修改的數據時, 不合理的存取和不完整的讀取數據4、持久性 事務提交以後,所做的工作就被永久的保存下來 示例:創建一個存儲過程,向兩個表中同時插入數據create proc registeruser(@usrname varchar(30),@usrpasswd varchar(30),@age int,@sex varchar(10),@phonenum varchar(20),@address varchar(50) )as beginbegin traninsert into userinfo(username,userpasswd)values(@usrname,@usrpasswd)if @@error<>0begin rollback tranreturn -1endinsert into userdoc(username,age,sex,phonenumber,address)values(@usrname,@age,@sex,@phonenum,@address)if @@error<>0begin rollback tranreturn -1endcommit tranreturn 0end事務的分類按事務的啟動與執行方式,可以將事務分為3類:顯示事務 也稱之為用戶定義或用戶指定的事務,即可以顯式地定義啟動和結束的事務。分布式事務屬於顯示事務自動提交事務默認事務管理模式。如果一個語句成功地完成,則提交該語句;如果遇到錯誤,則回滾該語句。隱性事務當連接以此模式進行操作時,sql將在提交或回滾當前事務後自動啟動新事務。無須描述事務的開始,只需提交或回滾每個事務。它生成連續的事務鏈。一、顯示事務通過begin transacton、commit transaction、commit work、rollback transaction或rollback work等語句完成。1、啟動事務格式:begin tran 事務名或變數 with mark 描述2、結束事務格式:commit tran 事務名或變數 (事務名與begin tran中的事務名一致或commit work 但此沒有參數3、回滾事務 rollback tran 事務名或變數 | savepoint_name | savepoint_variable 或rollback work 說明:清除自事務的起點或到某個保存點所做的所有數據修改4、在事務內設置保存點格式:save tran savepoint_name | savepoint_variable 示例:use bookdbgobegin tran mytraninsert into book values(9,"windows2000',1,22,'出版社')save tran mysavedelete book where book_id=9rollback tran mysavecommit trangoselect * from bookgo可以知道,上面的語句執行後,在book中插入了一筆記錄,而並沒有刪除。因為使用rollback tran mysave 語句將操作回滾到了刪除前的保存點處。5、標記事務格式:with mark 例:使用資料庫標記將日誌恢復到預定義時間點的語句 在事務日誌中置入一個標記。請注意,被標記的事務至少須提交一個更新,以標記該日誌。begin tran mymark with mark update pubs.dbo.lastlogmark set marktime = getdate() commit tran mymark 按照您常用的方法備份事務日誌。backup log pubs to disk='c:/backups/fullbackup.bak' with init 現在您可以將資料庫恢復至日誌標記點。首先恢復資料庫,並使其為接受日誌恢復做好准備。 restore database pubs from disk=n'c:/backups/fullbackup.bak' with norecovery 現在將日誌恢復至包含該標記的時間點,並使其可供使用。請注意,stopat在資料庫正在執行大容量日誌時禁止執行。 restore log pubs from disk=n'c:/backups/logbackup.bak' with recovery, stopat='02/11/2002 17:35:00'5、不能用於事務的操作創建資料庫 create database 修改資料庫 alter database 刪除資料庫 drop database 恢復資料庫 restore database 載入資料庫 load database 備份日誌文件 backup log 恢復日誌文件 restore log 更新統計數據 update statitics 授權操作 grant 復制事務日誌 mp tran 磁碟初始化 disk init 更新使用sp_configure後的系統配置 reconfigure二、自動提交事務 sql連接在begin tran 語句啟動顯式事務,或隱性事務模式設置為打開之前,將以自動提交模式進行操作。當提交或回滾顯式事務,或者關閉隱性事務模式時,將返回到自動提交模式。示例: 由於編譯錯誤,使得三個insert都沒執行use testgocreate table testback(cola int primary key ,colb char(3))goinsert into testback values(1,'aaa')insert into testback values(2,'bbb')insert into testback value(3,'ccc')goselect * from testbackgo 沒有任何結果返回三、隱式事務通過 api 函數或 transact-sql set implicit_transactions on 語句,將隱性事務模式設置為打開。下一個語句自動啟動一個新事務。當該事務完成時,再下一個 transact-sql 語句又將啟動一個新事務。當有大量的ddl 和dml命令執行時會自動開始,並一直保持到用戶明確提交為止,切換隱式事務可以用set implicit_transactions 為連接設置隱性事務模式.當設置為 on 時,set implicit_transactions 將連接設置為隱性事務模式。當設置為 off 時,則使連接返回到自動提交事務模式 語句包括: alter table insert open create delete revoke drop select fetch truncate table grant update 示例: 下面使用顯式與隱式事務。它使用@@tracount函數演示打開的事務與關閉的事務:use testgoset nocount oncreate table t1(a int)goinsert into t1 values(1)goprint '使用顯式事務'begin traninsert into t1 values(2)print '事務外的事務數目:' cast(@@trancount as char(5))commint tranprint '事務外的事務數目:' cast(@@trancount as char(5))goprintgoset implicit_transactions on go print '使用隱式事務'goinsert into t1 values*4)print'事務內的事務數目:' cast(@@trancount as char(5))commint tran print'事務外的事務數目:' cast(@@trancount as char(5))go執行結果: 使用顯示事務事務內的事務數目:2 事務外的事務數目:1 使用隱式事務事務內的事務數目:1 事務外的事務數目:0四、分布式事務跨越兩個或多個資料庫的單個sql server中的事務就是分布式事務。與本地事務區別:必須由事務管理器管理,以盡量避免出現因網路故障而導致一個事務由某些資源管理器成功提交,但由另一些資源管理器回滾的情況。 sql server 可以由dtc microsoft distributed transaction coordinator 來支持處理分布式事務,可以使用 begin distributed transaction 命令啟動一個分布式事務處理 分二階段:a 准備階段 b 提交階段執行教程:1、sql 腳本或應用程序連接執行啟動分布式事務的sql語句2、執行該語句的sql在為事務中的主控伺服器3、腳本或應用程序對鏈接的伺服器執行分布式查詢,或對遠程伺服器執行遠程存儲過程。4、當執行了分布式查詢或遠程過程調用後,主控伺服器將自動調用msdtc以便登記分布式事務中鏈接的伺服器和遠程伺服器5、當腳本或應用程序發出commit或rollback語句時,主控sql將調用msdtc管理兩階段提交過程,或者通知鏈接的伺服器和遠程伺服器回滾其事務。