ตอนที่ 13 : การ Debug Stored Procedure บน Visual Studio 2010,2012,2013,2015 และอื่น ๆ |
ตอนที่ 13 : การ Debug Stored Procedure บน Visual Studio 2010,2012,2013,2015 และอื่น ๆ สำหรับฟีเจอร์นี้ถือว่าเป็นจุดเล่นและความสามารถน่าสนใจมาก เพราะเหตุลผก็คือใน SQL Server รุ่นใหม่ ๆ มันสามารถใช้ Visual Studio ทำการ Debug ตัว Stored Procedure ร่วมกับการเขียนโปรแกรมอื่น ๆ บน Visual Studio ได้เลย ซึ่งปัญหาในการเขียน Stored ยุคแรก ๆ ก็คือแทบจะไม่มีวิธีการ Debug ตัว Stored Procedure ได้เลย การหาข้อผิดพลาดระหว่าง Runtime นั้นเป็นไปได้ยากมา นอกจากการใช้วิธี PRINT เพื่อดูค่าทาง Result ด้วยเหตุนี้เอง Stored Procedure จึงไม่ค่อยได้รับความนิยมมากนัก และถือว่าเป็นจุดเด่นมาก ๆ ที่ใน Visual Studio รุ่นใหม่ ๆ มีฟีเจอร์นี้ขึ้นมาด้วย โดยเราสามารถที่จะ Debug ได้เฉพาะ Stored Procedure ก็ได้ หรือจะ Debug โปรแกรมตั้งแต่ Application จนมาถึงการเรียกใช้งาน Stored Procedure
Stored สำหรับทดสอบในการ Debug โปรแกรม
CREATE PROCEDURE [dbo].[myStoredProcedure]
@pRow INT
AS
BEGIN
-- Declare Table
DECLARE @temp TABLE
(
RowID INT,
Name VARCHAR(50),
LastName VARCHAR(50)
)
-- Variable
DECLARE @i INT
SET @i = 1
-- Loop Insert Table
WHILE (@i <= @pRow)
BEGIN
INSERT INTO @temp (RowID,Name,LastName) VALUES ((@i),'Weerachai','Nukitram')
SET @i = @i + 1
END -- WHILE
-- Variable
DECLARE @j INT
DECLARE @iRow INT
DECLARE @sName VARCHAR(50)
DECLARE @sLastName VARCHAR(50)
-- Set Variable
SET @j = 1
SELECT @iRow = COUNT(*) FROM @temp
-- Loop Display Row
WHILE (@j <= @iRow)
BEGIN
-- Select from table
SELECT @sName = Name , @sLastName = LastName
FROM @temp WHERE RowID = @i
-- Print output
PRINT ' Row : ' + CONVERT(VARCHAR,@j) + ', Name : ' + @sName + ', LastName : ' + @sLastName
SET @j = @j + 1
END -- WHILE
END
Note!! Visual Studio 2010 สามารถ Debug ได้แค่ SQL Server 2008 ลงไป ส่วน รุ่นอื่น ๆ จะต้องใช้ให้สูงกว่า Version ที่โปรแกรม Limit ไว้
Example 1 การ Debug Stored Procedure บน Visual Studio 2010
data:image/s3,"s3://crabby-images/8b33c/8b33cf8b0be35953b4fcc0553470721d943e9df2" alt="Debug Stored Procedure Debug Stored Procedure"
เลือกที่ Server Explorer คลิกขวา Add Connection
data:image/s3,"s3://crabby-images/63dc7/63dc7fca5694efe1004c463ad739adc6ef55dc00" alt="Debug Stored Procedure Debug Stored Procedure"
ข้อมูลที่จะติดต่อกับ SQL Server
data:image/s3,"s3://crabby-images/f52af/f52af51fec57dbc1e1e1edb7e00243b4a3e1c4db" alt="Debug Stored Procedure Debug Stored Procedure"
รายการ SQL Server แสดงใน Server Explorer ของ Visual Studio
data:image/s3,"s3://crabby-images/e7767/e7767d89d8572121532b22b9910f3dcf06dc9e19" alt="Debug Stored Procedure Debug Stored Procedure"
เลือกชื่อ Stored Procedure ที่ต้องการ
data:image/s3,"s3://crabby-images/4b753/4b7533b55de1d2cd632326116c28e749631fe86d" alt="Debug Stored Procedure Debug Stored Procedure"
คลิกขวาเลือกที่ Open
data:image/s3,"s3://crabby-images/7a456/7a45627a5f41ff66cee0ef23489b6e4e648e353a" alt="Debug Stored Procedure Debug Stored Procedure"
หลังจากที่แสดง Stored Procedure เราสามารถกำหนด Breakpoints ที่จะ Debugได้
data:image/s3,"s3://crabby-images/9fef5/9fef578e40c07fd0762d8bde05491c8c9ac60970" alt="Debug Stored Procedure Debug Stored Procedure"
คลิกขวที่ Stored Procedure -> Step Info Stored Procedure
data:image/s3,"s3://crabby-images/39dfe/39dfe83a326b36d4d18de33dbec4c24fc21eaa8c" alt="Debug Stored Procedure Debug Stored Procedure"
ในกรณีที่ Stored มี Parameters จะแสดง Dialog ให้ทำการ Input ค่าต่าง ๆ
data:image/s3,"s3://crabby-images/c0c06/c0c06298f86b3f4cb1da4e36f77b5e017105ede2" alt="Debug Stored Procedure Debug Stored Procedure"
จากนั้นตัว Cursor จะวิ่งมายัง Breakpoints และหยุดให้เราตรวจสอบค่าต่าง ๆ ซึ่งสามารถ Debug Step ได้เหมือนกับ Visual Studio เช่น F10 , F11 , F5 เป็นต้น
data:image/s3,"s3://crabby-images/021e9/021e98df0f9ff1f256ca1b2c30f5cb23c9990854" alt="Debug Stored Procedure Debug Stored Procedure"
การ Control Step ต่าง ๆ
Example 2 การ Debug Stored Procedure บน Visual Studio 2012,2013 และอื่น ๆ
data:image/s3,"s3://crabby-images/046a1/046a166c53b73f37a36d5678fd2ceee0bd4e6095" alt="Debug Stored Procedure Debug Stored Procedure"
ในการ Debug ตัว Stored Procedure ตั้งแต่ Visual Studio 2012 ขึ้นไป
data:image/s3,"s3://crabby-images/5119a/5119aa8d2807f4e49d7d43a6bf4ae7a6c38add96" alt="Debug Stored Procedure Debug Stored Procedure"
ให้คลิกที่เมนู VIEW -> SQL Server Object Explorer
data:image/s3,"s3://crabby-images/f60f5/f60f541530c3df7bd08088654f9fa4d68fb1a663" alt="Debug Stored Procedure Debug Stored Procedure"
ในกรณีที่แสดงข้อความ
Untable to connect a database and browse object.
Incompatible version of sql server data tools and database runtime components are installed on this computer. Wen I click on Lear more... and Get the latest version of SQL Server Data Tools..., these two page are not available.
แสดงทำการดาวน์โหลดและติดตั้งตัว SQL Server Data Tools. ให้เรียบร้อยเสียก่อน
Microsoft SQL Server Data Tools
ล่าสุด
https://msdn.microsoft.com/en-us/library/mt204009.aspx
สำรอง
http://www.microsoft.com/en-us/download/details.aspx?id=36843
http://www.microsoft.com/en-us/download/details.aspx?id=42313
data:image/s3,"s3://crabby-images/01671/016711ab63daa8fe0e244720c2a4f376a9200cfe" alt="Debug Stored Procedure Debug Stored Procedure"
เลือก Version ให้ตรงกับ Visual Studio ที่กำลังใช้งาน
data:image/s3,"s3://crabby-images/a8c7e/a8c7eb5e157a57129122b3e399d9c23900111982" alt="Debug Stored Procedure Debug Stored Procedure"
ติดตั้ง Microsoft SQL Server Data Tools
data:image/s3,"s3://crabby-images/49eb8/49eb8d385e863a44a872e2f40ebe391ce1a62672" alt="Debug Stored Procedure Debug Stored Procedure"
แสดงรายการของ SQL Server
data:image/s3,"s3://crabby-images/b7b07/b7b078b3af8da5312c8de78512bf017d911c3f38" alt="Debug Stored Procedure Debug Stored Procedure"
คลิกขวาที่ SQL Server -> Add SQL Server
data:image/s3,"s3://crabby-images/33a30/33a305e13a8a93a1cc5fd0f060405571621d5e98" alt="Debug Stored Procedure Debug Stored Procedure"
ทำการ Authen ตัว SQL Server ที่จะเชื่อมต่อ
data:image/s3,"s3://crabby-images/f1a59/f1a59b1b9c93365b50040842c7e8da270b701cd2" alt="Debug Stored Procedure Debug Stored Procedure"
แสดงรายการของ SQL Server ที่ทำการ Add เข้ามา
data:image/s3,"s3://crabby-images/6a765/6a7657a8659308b64d707d761c48a333b0f9b30f" alt="Debug Stored Procedure Debug Stored Procedure"
เลือกที่ Stored Procedure ที่จะทำการ Debug
data:image/s3,"s3://crabby-images/98bc7/98bc74ee9474c967aad3e17403de4916920de08f" alt="Debug Stored Procedure Debug Stored Procedure"
คลิกวาเลือก Debug Procedure
data:image/s3,"s3://crabby-images/4de49/4de49c069e623c7e2edec6c166e10edaf565f674" alt="Debug Stored Procedure Debug Stored Procedure"
ใส่ค่า Parameters ในกรณีที่ต้องการให้มีค่าส่งไปด้วย
data:image/s3,"s3://crabby-images/9a318/9a31810a5e1a15921866d317e534835b6ed943b9" alt="Debug Stored Procedure Debug Stored Procedure"
โปรแกรมจะสร้าง New Query ให้ใหม่ โดย Input ค่าต่าง ๆ ไปให้ด้วย
data:image/s3,"s3://crabby-images/613d8/613d8c8b7f1c14436848ad7ee876b3b628bb88ae" alt="Debug Stored Procedure Debug Stored Procedure"
เราสามารถ Debug เข้าไปใน Step ย่อยของ Procedure ด้วยการกด F11
data:image/s3,"s3://crabby-images/c0274/c02740f1f5842937d503a365a27560164e3750fe" alt="Debug Stored Procedure Debug Stored Procedure"
ถ้ามี Breakpoint จะหยุดและแสดงค่าต่าง ๆ ของตัวแปร
|