Параметры поля проходов к сохраненной процедуре с использованием Entity Framework 4.1
-
27-10-2019 - |
Вопрос
Все,
Я застрял в следующем выпуске весь день. Я пытаюсь сделать параметризованный вызов с сохраненной процедурой, который включает в себя три битные параметры поля. Исключением, с которым я продолжаю сталкиваться, является «Ошибка преобразования типа данных NVARCHAR в бит».
Вот мой исходный код:
Хранимая процедура
ALTER PROCEDURE usp_TestParamProc
@price_segment_set_id VARCHAR(8) = NULL,
@segment_group_id VARCHAR(8) = NULL,
@segment_price_band_id VARCHAR(8) = NULL,
@segment_id VARCHAR(8) = NULL,
@include_source_price_bands BIT = 0,
@apply_segmentation BIT = 0,
@print_sql BIT = 0
AS
BEGIN
SET NOCOUNT ON;
SELECT *
FROM MarketingSegmentDetails
WHERE SegmentID = @segment_id
END
GO
C# код:
var segment_id = "1";
string segment_group_id = "1";
string segment_price_band_id = "1";
string price_segment_set_id = "1";
var include_source_price_bands = false;
var apply_segmentation = false;
var print_sql = false;
using (var context = new PricingContext())
{
var list = new List<object>();
list.Add(price_segment_set_id == null
? new SqlParameter("price_segment_set_id", DBNull.Value)
: new SqlParameter("price_segment_set_id", price_segment_set_id));
list.Add(segment_group_id == null
? new SqlParameter("segment_group_id", DBNull.Value)
: new SqlParameter("segment_group_id", segment_group_id));
list.Add(segment_price_band_id == null
? new SqlParameter("segment_price_band_id", DBNull.Value)
: new SqlParameter("segment_price_band_id", segment_price_band_id));
list.Add(segment_id == null
? new SqlParameter("segment_id", DBNull.Value)
: new SqlParameter("segment_Id", segment_id));
list.Add(include_source_price_bands == null
? new SqlParameter("include_source_price_bands", DBNull.Value)
: new SqlParameter("include_source_price_bands", Convert.ToBoolean(include_source_price_bands)));
list.Add(apply_segmentation == null
? new SqlParameter("apply_segmentation", DBNull.Value)
: new SqlParameter("apply_segmentation", Convert.ToBoolean(apply_segmentation)));
list.Add(print_sql == null
? new SqlParameter("print_sql", DBNull.Value)
: new SqlParameter("print_sql", Convert.ToBoolean(print_sql)));
var segments = context.Database.SqlQuery<usp_SegmentProcessing>("usp_TestParamProc price_segment_set_id, segment_group_id, segment_price_band_id, segment_id, include_source_price_bands, apply_segmentation, print_sql", list.ToArray()).ToList();
Любая помощь будет очень оценена. Я отстаю в проектной работе.
Спасибо, Дерек
Решение
Может попробовать сделать что -то вроде
list.Add(
new SqlParameter("print_sql", System.Data.SqlDbType.Bit) { Value = (print_sql != null ? print_sql : DBNull.Value) }
);
Не связан с StackOverflow