У меня есть этот общий репозиторий.
/// <summary>
/// Implémentation de base d'un dépositoire pour Entity Framework.
/// </summary>
/// <remarks>Entity Framework 4.1</remarks>
/// <typeparam name="TEntite">Entité spécifique.</typeparam>
public abstract class RepositoryBase<TEntity, TKey> : IRepository<TEntity>, IDisposable
where TEntity : EntityBase<TKey>
where TKey : class
{
private readonly IContext _context;
private ObjectContext _objectContext;
private IObjectSet<TEntity> _objectSet;
protected RepositoryBase(IContext context)
{
_context = context;
_objectContext = _context.GetObjectContext();
_objectSet = _objectContext.CreateObjectSet<TEntity>();
}
/// <see cref="IRepository.cs"/>
public IEnumerable<TEntity> GetAll(Expression<Func<TEntity, object>> sortExpression)
{
if (sortExpression == null)
sortExpression = x => x.Id;
return _objectSet.OrderBy(sortExpression).AsEnumerable();
}
/// <see cref="IRepository.cs"/>
public IEnumerable<TEntity> GetAll(int maximumRows, int startRowIndex, Expression<Func<TEntity, object>> sortExpression)
{
if (sortExpression == null)
sortExpression = x => x.Id;
return _objectSet.OrderBy(sortExpression).Skip(startRowIndex).Take(maximumRows).AsEnumerable();
}
/// <see cref="IRepository.cs"/>
public TEntity SelectByKey(TKey key)
{
if (key == null)
throw new ArgumentNullException("La clé était NULL! Une clé est nécessaire pour récupérer un entité.");
return _objectSet.SingleOrDefault(x => x.Id == key);
}
Здесь конкретная реализация ...
public class ProductRepository : RepositoryBase<Product, int>, IProductRepository
{
public ProductRepository(IContext context)
: base(context)
{ }
/// <see cref="IProductRepository.cs"/>
public Product GetByName(string name)
{
return base.First(x => x.Name == name);
}
/// <see cref="IProductRepository.cs"/>
public IEnumerable<Product> FindProduct(Specification<Product> specification)
{
throw new System.NotImplementedException();
}
}
Когда я создаю конкретный репозиторий.это говорит о том, что Tkey должен быть ссылочным типом, но почему?Есть ли способ заставить этот общий репозиторий работать?TKey использовался для того, чтобы метод SelectByKey принимал тип ключа.
Edit # 1:
Если я уберу ограничение, у меня возникнет другая проблема ...TKey нельзя сравнивать с TKey, используя == как лямбда-выражение в моем методе SelectByKey.
Edit # 2:
Пытался использовать Equals, и синтаксис вроде бы в порядке.
Edit # 3:
Эквалайз равно во время выполнения .. говоря, что Tkey (который выглядит как System.Object) не может использовать equals, что не выглядит логикойпоскольку объект имеет равный метод.В настоящее время у меня нет доступа к реальному коду, но я провел несколько тестов с этим кодом ниже ..
class Program
{
static void Main(string[] args)
{
Test<TestEntity, int> t = new Test<TestEntity, int>();
t.TestMethod(5);
}
}
class Test<TEntity, TKey>
where TEntity : Entity<TKey>
{
public Test()
{ }
public TestEntity TestMethod(TKey id)
{
List<TestEntity> testEntity = new List<TestEntity>();
testEntity.Add(new TestEntity(5));
return testEntity.SingleOrDefault(x => x.Id.Equals(id));
}
}
class Entity<TKey>
{
public TKey Id { get; set; }
}
class TestEntity : Entity
{
public TestEntity(int id)
{
Id = id;
}
}
class Entity : Entity<int>
{
}
И, похоже, он работает довольно хорошо.Поэтому я попробую позже сегодня вечером.
Edit # 4
Хорошо, исключение, которое я получаю, - Canoot создает постоянное значение типа "System.Object".В этом контексте поддерживаются только основные типы, такие как int32, string и guid.