如何将测试数据table作为存储过程中的参数传递
How to pass a test data table as a parameter in a stored procedure
我有一个要测试的存储过程。它使用一个已经创建的 User-Defined Table Type ([TicketFields])
,它本质上只有一个名为 fieldNames
的列,其中包含 nvarchar
个字段名称('Requestor Name、Requestor Org,等等...)。然后它创建一个临时 table 使用 @keyword
用户参数在所选字段名称中搜索该关键字。我的问题是,当我执行它进行测试时,我不能简单地插入一个 datatable
作为参数。
ALTER PROCEDURE [dbo].[bcasp_GetTicketsByKeyword]
@Keyword nvarchar(150),
@fieldsTable [TicketsFields] READONLY
AS
BEGIN
CREATE TABLE #Ticket(
[ID] [bigint] NULL,
[TicketNumber] [nvarchar](255) NULL,
[Complexity] [nvarchar](255) NULL,
[NatureOfInquiry] [nvarchar](255) NULL,
[SMEResponseDetail] [nvarchar](255) NULL
)
declare @fieldName nvarchar(100)
declare @sql nvarchar(max)
declare @initSql nvarchar(max)
set @initSql = 'insert into #Ticket (ID, TicketNumber, Complexity,
NatureOfInquiry, SMEResponseDetail) SELECT ID, TicketNumber, Complexity,
CASE
WHEN Complexity = 1 THEN NatureOfInquiry_T1
WHEN Complexity In (2,3,4) THEN NatureOfInquiry_T234
END, SMEResponseDetail FROM T_Ticket WHERE '
declare @whereClause nvarchar(100)
set @whereClause = ' Like' + '''%' + @Keyword + '%'''
DECLARE tblCursor CURSOR FOR SELECT FieldName from @fieldsTable
OPEN tblCursor
FETCH NEXT from tblCursor into @fieldName
WHILE @@FETCH_STATUS = 0
BEGIN
set @sql = @initsql + @fieldName + @whereClause
print @sql
EXEC(@sql)
FETCH NEXT from tblCursor into @fieldName
END
Close tblCursor
deallocate tblCursor
select distinct * from #Ticket
END
场景假设想要在 "NatureOfInquiry" 和 "SMEResponseDetail" 的 fieldNames
列中搜索 keyword
"flood"。我可以在下面插入什么来模拟它并将正确的行获取到 return?
USE [BCATicketManagementTest]
GO
DECLARE @return_value int
EXEC @return_value = [dbo].[bcasp_GetTicketsByKeyword]
@Keyword = N'flood'
???
SELECT 'Return Value' = @return_value
GO
怎么样
USE [BCATicketManagementTest]
GO
DECLARE @return_value int
DECLARE @fieldsTableTest [TicketsFields]
INSERT INTO @fieldsTableTest
SELECT 'CUSTOMERID' UNION ALL SELECT 'MANAGERID' UNION ALL SELECT 'SOME OTHER FIELD'
EXEC @return_value = [dbo].[bcasp_GetTicketsByKeyword]
@Keyword = N'flood'
@fieldsTable = @fieldsTableTest
SELECT 'Return Value' = @return_value
GO
我不确定如何使用 SSMS 完成此任务。
我有一个要测试的存储过程。它使用一个已经创建的 User-Defined Table Type ([TicketFields])
,它本质上只有一个名为 fieldNames
的列,其中包含 nvarchar
个字段名称('Requestor Name、Requestor Org,等等...)。然后它创建一个临时 table 使用 @keyword
用户参数在所选字段名称中搜索该关键字。我的问题是,当我执行它进行测试时,我不能简单地插入一个 datatable
作为参数。
ALTER PROCEDURE [dbo].[bcasp_GetTicketsByKeyword]
@Keyword nvarchar(150),
@fieldsTable [TicketsFields] READONLY
AS
BEGIN
CREATE TABLE #Ticket(
[ID] [bigint] NULL,
[TicketNumber] [nvarchar](255) NULL,
[Complexity] [nvarchar](255) NULL,
[NatureOfInquiry] [nvarchar](255) NULL,
[SMEResponseDetail] [nvarchar](255) NULL
)
declare @fieldName nvarchar(100)
declare @sql nvarchar(max)
declare @initSql nvarchar(max)
set @initSql = 'insert into #Ticket (ID, TicketNumber, Complexity,
NatureOfInquiry, SMEResponseDetail) SELECT ID, TicketNumber, Complexity,
CASE
WHEN Complexity = 1 THEN NatureOfInquiry_T1
WHEN Complexity In (2,3,4) THEN NatureOfInquiry_T234
END, SMEResponseDetail FROM T_Ticket WHERE '
declare @whereClause nvarchar(100)
set @whereClause = ' Like' + '''%' + @Keyword + '%'''
DECLARE tblCursor CURSOR FOR SELECT FieldName from @fieldsTable
OPEN tblCursor
FETCH NEXT from tblCursor into @fieldName
WHILE @@FETCH_STATUS = 0
BEGIN
set @sql = @initsql + @fieldName + @whereClause
print @sql
EXEC(@sql)
FETCH NEXT from tblCursor into @fieldName
END
Close tblCursor
deallocate tblCursor
select distinct * from #Ticket
END
场景假设想要在 "NatureOfInquiry" 和 "SMEResponseDetail" 的 fieldNames
列中搜索 keyword
"flood"。我可以在下面插入什么来模拟它并将正确的行获取到 return?
USE [BCATicketManagementTest]
GO
DECLARE @return_value int
EXEC @return_value = [dbo].[bcasp_GetTicketsByKeyword]
@Keyword = N'flood'
???
SELECT 'Return Value' = @return_value
GO
怎么样
USE [BCATicketManagementTest]
GO
DECLARE @return_value int
DECLARE @fieldsTableTest [TicketsFields]
INSERT INTO @fieldsTableTest
SELECT 'CUSTOMERID' UNION ALL SELECT 'MANAGERID' UNION ALL SELECT 'SOME OTHER FIELD'
EXEC @return_value = [dbo].[bcasp_GetTicketsByKeyword]
@Keyword = N'flood'
@fieldsTable = @fieldsTableTest
SELECT 'Return Value' = @return_value
GO
我不确定如何使用 SSMS 完成此任务。