我需要将一个列表传递给我的SQL Server存储过程。我已生成的列表中,这是一个逗号分隔的使用数字的列表:我想将一个评估列表传递给我的SQL Server存储过程
<cfquery name="House" datasource="#application.datasource#">
SELECT cGLsubaccount
FROM HOUSE
WHERE Right(cGLsubaccount,3) IN
(
<cfloop index="i" list="#consulsub#">
<cfoutput>#right(Trim(i) , 3)#,</cfoutput>
</cfloop>
00000000
)
</cfquery>
<cfset GLsubacct = Valuelist(House.cGLsubaccount,",")>
现在,我将它传递到使用cfprocparam
与cfsqltype为varchar(1000)的存储过程。 (我在google上读到这是将列表传递给存储过程的方式)。
<cfprocparam type="IN" value="#GLsubacct#" DBVARNAME="@GLsubacct" cfsqltype="cf_sql_varchar">
在存储过程中,我这样做:
ALTER PROCEDURE [rw].[sp_EFT_NoticeXLS2] (
@Scope varchar(50)
, @AcctPeriod char(6)
, @CompanyID nchar(10)
, @GLsubacct varchar(1000) = NULL
)
AS......
,并在存储过程中的SQL语句如下:
CREATE TABLE #Houses (
iHouse_ID int,
cName varchar(50),
cNumber varchar(10),
cPhoneNumber1 varchar(25),
cAddressLine1 varchar(50),
cCity varchar(30),
cStateCode varchar(2),
cZipCode varchar(10),
iUnitsAvailable int,
iRegOpsNumber int,
cOpsName varchar(50),
iRegionID int,
cRegionName varchar(50)
)
INSERT INTO #Houses (
iHouse_ID,
cName,
cNumber,
cPhoneNumber1,
cAddressLine1,
cCity,
CStateCode,
cZipCode,
iUnitsAvailable,
iRegOpsNumber,
cOpsName,
iRegionID,
cRegionName)
SELECT
h2.iHouse_ID,
h.cName,
h.cNumber,
h.cPhoneNumber1,
h.cAddressLine1,
h.cCity,
h.CStateCode,
h.cZipCode,
h.iUnitsAvailable,
r.RegOpsNumber,
r.opsname,
r.iRegion_ID,
r.regionname
FROM rw.fn_GetScopeHouses (@Scope, @dtReport, NULL, NULL, 0) h2
JOIN House h on h.iHouse_ID = h2.iHouse_ID
AND h.cCompanyID = @CompanyID
AND (@GLsubacct IS NULL OR h.iHouse_ID IN ('+ @GLsubacct +'))
JOIN rw.vw_Reg_Ops r on r.opsareaID = h.iOpsArea_ID
的问题是,我得到一个错误。错误信息是...
Error Executing Database Query.
[Macromedia][SQLServer JDBC Driver][SQLServer]Conversion failed when converting the varchar value '+ @GLsubacct +' to data type int.
The error occurred in E:\inetpub\wwwroot\intranet\TIPS4\Admin\EFTprocesspullfile.cfm: line 46
44 : <cfprocparam type="IN" value="#CompanyID#" DBVARNAME="@CompanyID" cfsqltype="cf_sql_varchar"><!--- TPecku added variable to be passed to the stored Proc --->
45 : <cfif CompanyID EQ 0000>
46 : <cfprocparam type="IN" value="#GLsubacct#" DBVARNAME="@GLsubacct" cfsqltype="cf_sql_varchar">
47 : </cfif>
48 : </cfstoredproc>
错误在存储过程中,因为那是我的'+ @GLsubacct +'。 关于我在做什么的任何想法都是错误的? (对不起,很长一段时间,我想尽可能详细地描述我在做什么
查看表值参数(TVP),这可能是您想要使用而不是传递字符串。 https://msdn.microsoft.com/en-us/library/bb510489.aspx – rjdevereux
谢谢rjdevereux,我看着你的链接,但我仍然困惑于如何前进。 – Tetteh
那么,你有几个选择。一种是使用字符串解析功能。以下是一些你可以做到的方法:https://sqlperformance.com/2012/07/t-sql-queries/split-strings。一种是将表传递给存储过程。要做到这一点,你需要创建一个类型(如上面的链接),然后使用它作为你的过程的'READONLY'参数。无论您选择什么选项,您都希望更改您的过程以加入表格(分割值表或您使用的tvp)。 – ZLK