SQL-инъекция после удаления всех одинарных кавычек и тире

В настоящее время я пытаюсь реализовать репозитории для своих объектов домена с помощью RC Entity Framework 4.1 и его подхода, основанного на коде. Теперь у меня есть объект домена "Voyage", уникальный идентификатор которого инкапсулирован в тип "VoyageNumber"

public class VoyageNumber
{
    private readonly string number;

    public VoyageNumber(string number)
    {
        Validate.NotNull(number, "VoyageNumber is required");

        this.number = number;
    }

    public string Id
    {
        get { return number; }
    }

. Теперь я получаю исключение, когда я делаю это в конфигурации моего DbContext:

modelBuilder.Entity<Voyage>().HasKey<VoyageNumber>(k => k.VoyageNumber);

Свойство "VoyageNumber" не может быть используется в качестве ключевого свойства объекта 'Domain.Model.Voyages.Voyage', потому что тип свойства не является допустимым ключом тип. Только скалярные типы, строка и byte [] - это поддерживаемые типы ключей.

а также, когда я пробую это:

modelBuilder.Entity<Voyage>().HasKey<string>(k => k.VoyageNumber.Id);

Выражение свойств 'k => k.VoyageNumber.Id 'недействителен. В выражение должно представлять property: C #: 't => t.MyProperty'

Действительно ли мне нужно выбросить мой VoyageNumber и заменить его примитивным типом?

11
задан Ladislav Mrnka 2 April 2011 в 11:42
поделиться