是否可以将参数数组传递给通过CFQL生成的存储过程?
我们从设计器生成方法,没有任何问题。但是我还没有找到在Server上执行它的任何方法。
当试图通过代码执行时,如果出现给定的错误,代码将失败:
操作数类型冲突:表类型与int不兼容
在生成的行上:
System.Data.IDataReader reader = CodeFluentContext.Get(XYZ.Constants.XYZCodeFluentStoreName).Persistence.ExecuteReader();
CFQL机构如下:
LOAD (enumABCGroup[] groups) WHERE ABC.Group IN (@groups) ORDER BY NumberExt
生成的过程是:
CREATE PROCEDURE [XYZ].[ABC_LoadByGroups]
(
@groups [int],
@_orderBy0 [nvarchar] (64) = NULL,
@_orderByDirection0 [bit] = 0
)
AS
SET NOCOUNT ON
SELECT DISTINCT ...
FROM [XYZ].[ABC]
WHERE [XYZ].[ABC].[ABC_Group] IN (@groups)
ORDER BY [XYZ].[ABC].[ABC_Group] ASC, [XYZ].[ABC].[ABC_Label] ASC
RETURN
GO
底层数据库系统是SQL Server 2012 (v11.0.5058.0)。
感谢您的帮助;
发布于 2016-03-08 02:54:05
我认为您忘记将Server生成器配置为至少针对Server 2008:
或者在XML中:
<cf:producer name="SQL Server" typeName="CodeFluent.Producers.SqlServer.SqlServerProducer, CodeFluent.Producers.SqlServer">
<cf:configuration targetVersion="Sql2008" />
</cf:producer>
下面是一些关于CodeFluent实体和TVP的有用资源:
https://stackoverflow.com/questions/35864156
复制相似问题