Как преобразовать типы свойств DTO в типы CLR в DapperC#

Место общения программистов C#
Ответить
Anonymous
 Как преобразовать типы свойств DTO в типы CLR в Dapper

Сообщение Anonymous »

Я использую в проекте Dapper и Dapper.Contrib. Я хочу абстрагироваться от типа, используемого для ключей в моем Dto, чтобы можно было легко изменить его в будущем.
Приведенный ниже код вызывает исключение System.NotSupportedException, говорящее: «Член 'X' типа 'Y' не может использоваться в качестве значения параметра"

Код: Выделить всё

static void Main(string[] args)
{
using (var connection = new SqlConnection("server=.;database=equus;integrated security=true;Encrypt=false"))
{
connection.Open();
connection.Execute(@"If not exists (select name from sysobjects where name = 'User')
CREATE TABLE dbo.[User](UserId int identity(1,1) primary key clustered, Name varchar(200))");
var user = new User() { Name ="OSO", UserId = 1 };
connection.Insert(user);
connection.Close();
}
}

public struct Key
{
private readonly int _value;
public Key(int value) { _value = value; }
public static implicit operator Key(int value) { return new Key(value); }
public static implicit operator int(Key key) { return key._value; }
}

public class User
{
public Key UserId { get; set; }
public string Name { get; set; }=string.Empty;
}
Я знаю, что могу выполнить приведение вручную, например:

Код: Выделить всё

connection.Execute("INSERT INTO dbo.[User] (UserId, Name) values(@UserId, @Name)",
new {UserId=user.UserId, user.Name});
но я бы хотел использовать методы Dapper.Contrib, такие как Insert или Update
Я знаю, что могу использовать SqlMapper.SetTypeMap для выполнения определенного уровня манипуляций, например сопоставления имен столбцов, но я не могу найти способ сообщить Dapper, что «каждый раз, когда вы найдете свойство типа T, преобразуйте его в CLR типа C с использованием этого делегата». Есть предложения?

Подробнее здесь: https://stackoverflow.com/questions/786 ... -in-dapper
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»