2012-06-17 111 views
0

我是新手Windows Phone 7開發人員,我遇到了Linq to SQL問題。我試圖更新一個對象,但它不起作用。我得到想要更新的對象並修改了我想要的屬性,但是當我調用SaveChanges時,它的數據沒有在數據庫上更新。Linq-to-SQL不在WP7上更新

我已經使用ISETool下載了數據庫,並且檢查數據沒有更新。

奇怪的是查詢和插入方法工作正常,但我不知道爲什麼更新它不是。

這裏的實體和更新方法的代碼:

[Table] 
public class Entrada : INotifyPropertyChanged, INotifyPropertyChanging 
{ 
    private int _Id; 
    [Column] 
    private int _DiaId; 
    [Column] 
    private int _ProjetoId; 

    private EntityRef<Dia> _Dia; 
    private EntityRef<Projeto> _Projeto; 

    private DateTime _Chegada;   
    private DateTime? _Saida; 

    [Column(IsPrimaryKey = true, IsDbGenerated = true, CanBeNull = false, DbType = "INT NOT NULL Identity")] 
    public int Id 
    { 
     get 
     { 
      return _Id; 
     } 
     set 
     { 
      if (value != _Id) 
      { 
       NotifyPropertyChanging("Id"); 
       _Id = value; 
       NotifyPropertyChanged("Id"); 
      } 
     } 
    } 

    [Column(CanBeNull=false)] 
    public DateTime Chegada 
    { 
     get 
     { 
      return _Chegada; 
     } 
     set 
     { 
      if (value != _Chegada) 
      { 
       _Chegada = value; 
       NotifyPropertyChanged("Chegada"); 
      }      
     } 
    } 

    [Association(Storage = "_Dia", ThisKey = "_DiaId", OtherKey="Id", IsForeignKey=true)] 
    public Dia Dia 
    { 
     get { return _Dia.Entity; } 
     set 
     { 
      NotifyPropertyChanging("Dia"); 
      _Dia.Entity = value; 

      if (value != null) 
      { 
       _DiaId= value.Id; 
      } 

      NotifyPropertyChanging("Dia"); 
     } 
    } 

    [Column(CanBeNull=true)] 
    public DateTime? Saida 
    { 
     get 
     { 
      return _Saida; 
     } 
     set 
     { 
      if (value != _Saida) 
      { 
       _Saida = value; 
       NotifyPropertyChanged("Saida"); 
      }      
     } 
    } 

    [Association(Storage = "_Projeto", ThisKey = "_ProjetoId", OtherKey = "Id", IsForeignKey = true)] 
    public Projeto Projeto 
    { 
     get 
     { 
      return _Projeto.Entity; 
     } 
     set 
     { 
      NotifyPropertyChanging("Projeto"); 
      _Projeto.Entity = value; 

      if (value != null) 
      { 
       _ProjetoId = value.Id; 
      } 

      NotifyPropertyChanging("Projeto"); 
     } 
    } 

    public event PropertyChangedEventHandler PropertyChanged; 
    public event PropertyChangingEventHandler PropertyChanging; 

    private void NotifyPropertyChanged(String propertyName) 
    { 
     if (null != PropertyChanged) 
     { 
      PropertyChanged(this, new PropertyChangedEventArgs(propertyName)); 
     } 
    } 

    private void NotifyPropertyChanging(string propertyName) 
    { 
     if (PropertyChanging != null) 
     { 
      PropertyChanging(this, new PropertyChangingEventArgs(propertyName)); 
     } 
    } 
} 

//UPDATE CODE: 
var query = (from e in timeSheetDB.Entradas where e.Dia.Id == this.Dia.Id && (!e.Saida.HasValue) select e); 
var entrada = query.FirstOrDefault(); 
if (entrada != null) 
{ 
    entrada.Saida = DateTime.Now; 
} 
timeSheetDB.SubmitChanges(); 

我還檢查GetChangeSet()Updates.Count(),但它總是0。我希望你能幫助我:-) 謝謝你們!

回答

0

它似乎是你沒有提高事件的Saida財產;這個事件對於LINQ到SQL來說很重要,所以我建議更新代表列的所有成員來提高它(除了PropertyChanged事件)

+0

非常感謝! 我真的忘了提高PropertyChanging的一些屬性!問題出現在我面前,我看不到它:-) – rmoreira