BLToolkit: Cercando di aggiornare un'entità e ottenere “non può convertire in errori di SQL”
Domanda
Ho un metodo di aggiornamento:
protected int ProcessUpdate(TUpdateDto updateDto, Func<IQueryable<TEntity>, IUpdateable<TEntity>> firstSetter, params Func<IUpdateable<TEntity>, IUpdateable<TEntity>>[] setters)
{
Checker.AssertNull(updateDto);
int id = updateDto.Id.FailIfNull();
IQueryable<TEntity> query = from item in new Table<TEntity>()
where item.Id == id
select item;
IUpdateable<TEntity> updateable = firstSetter(query);
foreach (var setter in setters)
{
setter(updateable);
}
Checker.AssertNull(updateable);
updateable.Update();
return id;
}
E entità:
[TableName("Test")]
public class Test
{
[PrimaryKey, Identity]
public int Id { get; set; }
public string Field1 { get; set; }
}
E qui è il codice di aggiornamento:
ProcessUpdate(updateDto, x => x.Set(e => e.Id, updateDto.Id),
x => x.Set(e => e.Field1, updateDto.Field1));
Quando si tenta di aggiornare una voce in una tabella ottengo " 'Convert (voce) .ID' non può essere convertito in SQL." errore. Non ho cercato di aggiornamento id e risultati erano gli stessi. Vorrei poter trovare la soluzione, ma non ci riesco. Grazie per le vostre risposte.
Soluzione
La soluzione è stata sulla modifica fonti BLToolkit.
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow