2015-11-04 16 views
8

Satır kimliğim var, ardından diğer değerleri güncelleyeceğim.Windows 10 C# sqlite.net pcl satır güncelleştirme nasıl?

Değerlerimi nasıl güncelleyeceğimi bilmiyorum! Benim Tablo:

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

diğer bilgiler:

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

Lütfen bu makaleye bakın http://blog.tpcware.com/2014/05/universal-app-with-sqlite-part-2/ Universal uygulamasına yazsa da Windows 10 uygulamasıyla da çalışacağını düşünüyorum. – Janak

cevap

7

Geçenlerde UWP uygulamalar ile çalışmaya başladı ve aynı zamanda bu soruna rastladı. Yani, UWP'de SQLite kullanarak bir satırı nasıl güncellersiniz? İşte git!

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); 
      }); 
     } 
    } 

App.DB_PATH, 'path' değişkeninizle aynıdır. Bu cevapta birçok farklı ilgi alanının olduğunu anlıyorum, bu yüzden başka sorularınız varsa, sormaya çekinmeyin.

2

sadece satırdaki değerlerin belirli bir grup güncellemek için, daha sonra bir ham SQL sorgusu yürütme kolay olurdu:

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

Bu temizlendikten sen yürütmek açıklamaya geçiyoruz girişi varsayar.

+0

sonra hemen bunu viewmodel nesnesine güncellemem gerekiyor mu? en iyi yolu? –