2015-11-04 13 views
8

Ho ID di riga, quindi aggiornerò altri valori.Come aggiornare la riga in sqlite.net pcl in windows 10 C#?

Non so come aggiornare i miei valori! My Table:

class MyTable 
{ 
    [PrimaryKey, AutoIncrement] 
    public int Id { get; set; } 
    public string Date { get; set; } 
    public string Volumes { get; set; } 
    public string Price { get; set; } 
} 

altre informazioni:

string path; 
    SQLite.Net.SQLiteConnection conn; 

    public updatepage() 
    { 
     this.InitializeComponent(); 
     path = Path.Combine(Windows.Storage.ApplicationData.Current.LocalFolder.Path, "ccdb.sqlite"); 

     conn = new SQLite.Net.SQLiteConnection(new SQLite.Net.Platform.WinRT.SQLitePlatformWinRT(), path); 

     conn.CreateTable<MyTable>(); 
    } 
+1

Si prega di fare riferimento a questo articolo http://blog.tpcware.com/2014/05/universal-app-with-sqlite-part-2/ anche se dice all'app universale ma penso che funzioni anche con l'app di Windows 10. – Janak

risposta

7

Recentemente ho iniziato a lavorare con le applicazioni UWP, e anche sono imbattuto in questo problema. Quindi, come aggiornare una riga utilizzando SQLite in UWP che chiedi? Eccoti!

using (var dbConn = new SQLiteConnection(new SQLite.Net.Platform.WinRT.SQLitePlatformWinRT(), App.DB_PATH)) 
    { 
     var existingUser = dbConn.Query<User>("select * from User where Id = ?", user.Id).FirstOrDefault(); 
     if (existingUser != null) 
     { 
      existingUser.Name = user.Name; 
      existingUser.Email = user.Email; 
      existingUser.Username = user.Username; 
      existingUser.Surname = user.Surname; 
      existingUser.EmployeeNumber = user.EmployeeNumber; 
      existingUser.Password = user.Password; 
      dbConn.RunInTransaction(() => 
      { 
       dbConn.Update(existingUser); 
      }); 
     } 
    } 

L'App.DB_PATH è la stessa della variabile "percorso". Mi rendo conto che ci sono molte aree di interesse in questa risposta, quindi se hai ulteriori domande, non esitare a chiedere.

2

aggiornare solo uno specifico insieme di valori di una riga, poi eseguendo una query SQL prime sarebbe più semplice:

conn.Execute("UPDATE MyTable SET Price = ? Where Id = ?", 1000000, 2); 

Ciò presuppone l'ingresso si passa alla comunicazione esecuzione è stata pulita.

+0

quindi devo immediatamente aggiornarlo all'oggetto viewmodel? in ogni modo migliore? –