SQLserver存儲過程寫法與設置定時執(zhí)行存儲過程方法詳解
最近工作中需要寫SQLserver的存儲過程,第一次使用,簡單記錄下,以防遺忘。
在SQLserver可視化工具中編寫,我的工具如下圖:
首先點擊你的數據庫,找到可編程性,在可編程性里面右擊存儲過程-->點擊新建存儲過程
然后開始寫你的存儲過程SQL
--寫法(無參): USE [Test] --[Test]使用的數據來源(數據庫名) GO /****** Object: StoredProcedure [dbo].[PR_ShowData] Script Date: 2022/11/12 13:58:38 ******/ --[dbo].[PR_ShowData]新建存儲過程,[dbo].[PR_ShowData]是存儲過程名 SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO ALTER PROCEDURE [dbo].[PR_ShowData] --修改存儲過程,[dbo].[PR_ShowData]是存儲過程名 AS BEGIN declare @FLAG VARCHAR(50) --如果需要變量的話,則是用此方法定義變量,類型根據需要自定義 --將D表中條件為P01=0的P02值查出來賦值給變量@FLAG SELECT @FLAG=P02 from D where P01 = '0' --判斷變量值,執(zhí)行判斷條件里面的SQL語句,這里if里面必須要寫開頭的begin與結束的end if (@FLAG=0) --如果變量值為0,就刪除A,B,C三個表里的數據,否則就插入數據 begin delete A delete B delete C end insert into A (字段A,字段B,.....)VALUES(數據1,數據2,.....) insert into B (字段A,字段B,.....)VALUES(數據1,數據2,.....) insert into C (字段A,字段B,.....)VALUES(數據1,數據2,.....) END
如上就是一個簡單的存儲過程了,完成后點擊執(zhí)行就行了。以上可以簡單理解為,用到的數據庫是[Test]數據庫,新建的存儲過程是[dbo].[PR_ShowData],因為我的業(yè)務是需要根據D表的條件更新A,B,C三個表的數據的,所以判斷了結果后根據條件先把A,B,C三個表的原有數據刪除或者保留,然后把需要的數據再插入到A,B,C三個表中。
剛開始時在這里踩了一個坑,插入時一直報錯
以A表舉例:
如果插入的數據只是一段固定的值,則字段和數據之間要用VALUES,格式insert into A (字段A,字段B,.....)VALUES(數據1,數據2,.....);
如果是從其他表查出來的數據結果,則不使用VALUES,直接insert into A (字段A,字段B,.....)(select * from 數據來源表名);只要字段對應即可。
ALTER PROCEDURE 相對于Create PROCEDURE優(yōu)點:
(1)ALTER PROC 期望找到現(xiàn)存的存儲過程,而CERATE不是。
(2)ALTER PROC 保留了已經建立的存儲過程的任何權限。它在系統(tǒng)對象中保留了相同的對象ID并允許保留依賴關系。
例如,如果過程A調用過程B,并刪除和重新創(chuàng)建了過程B,那么就不能再看到這兩者之間的依賴關系。如果使用ALTER,則依賴關系依然存在。
(3) ALTER PROC 在其他對象上保留了任何依賴關系的信息,這些對象可以調用修改的存儲過程。
編寫執(zhí)行的腳本,比如多久執(zhí)行一次存儲過程等
找到SQL Server代理,右擊作業(yè)-->新建作業(yè)
1.常規(guī)(名稱自己定義,確定即可)
2.點擊步驟-->點擊最下面的新建
2.1)步驟名稱(一般是exec 存儲過程名,我的是exec [dbo].[PR_ShowData])
2.2)類型選擇Transact-SQL 腳本(T-SQL)
2.3)數據庫選擇你的數據庫
2.4)命令exec PR_ShowData,最后點擊確定即可。
3.點擊計劃-->新建
3.1)名稱寫2.4)中的,我的是exec PR_ShowData
3.2)計劃類型根據自己的業(yè)務需求,我是重復執(zhí)行,后面的已啟用打勾
3.3)頻率-->執(zhí)行(我選擇的是每天)-->執(zhí)行間隔(我選的1天)
3.4)每天頻率我選擇的是執(zhí)行間隔十分鐘執(zhí)行一次,開始時間和結束時間根據自己需要選擇時間段
3.5)持續(xù)時間(開始和結束時間自己選擇,如果要一直執(zhí)行就選擇無結束日期)
3.6)摘要-->說明(會把你設置的信息總結,可以看是不是復合自己的要求)
3.7)最后點擊確定即可
我這里計劃列表顯示的有是因為我已經建過了。
如上便實現(xiàn)了SQLserver存儲過程簡單寫法與設置定時執(zhí)行存儲過程方法了
總結
到此這篇關于SQLserver存儲過程寫法與設置定時執(zhí)行存儲過程的文章就介紹到這了,更多相關SQLserver設置定時執(zhí)行存儲過程內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
sqlserver中將varchar類型轉換為int型再進行排序的方法
sql中把varchar類型轉換為int型然后進行排序,如果我們數據庫的ID設置為varchar型的 在查詢的時候order by id的話2012-06-06sql cast,convert,QUOTENAME,exec 函數學習記錄
將某種數據類型的表達式顯式轉換為另一種數據類型。CAST 和 CONVERT 提供相似的功能。2009-10-10SQL?Server數據庫表的創(chuàng)建與管理操作大全
這篇文章主要給大家介紹了關于SQL?Server數據庫表的創(chuàng)建與管理操作的相關資料,?SQL?Server是一個關系型數據庫管理系統(tǒng),它可以幫助用戶創(chuàng)建、管理和查詢數據,文中介紹的非常詳細,需要的朋友可以參考下2024-01-01