本文整理汇总了C#中ProductRepository.Commit方法的典型用法代码示例。如果您正苦于以下问题:C# ProductRepository.Commit方法的具体用法?C# ProductRepository.Commit怎么用?C# ProductRepository.Commit使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类ProductRepository
的用法示例。
在下文中一共展示了ProductRepository.Commit方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: SyncTable_Product
/// <summary>
/// Sync logic for product table
/// </summary>
private void SyncTable_Product()
{
var localTable = new ProductRepository<Product>(_localSessionContext);
var remoteTable = new ProductRepository<Product>(_remoteSessionContext);
OnSyncStart?.Invoke(this, new SyncStartedArgs("Product"));
#region SyncCode
var count = 0;
var total = localTable.Count();
foreach (var row in localTable.GetAll())
{
// Copy object and save (this removes ID)
var newObject = ObjectCopy.Copy(row);
remoteTable.Save(newObject);
// Save changes to remote
remoteTable.Commit();
// Create a sync record this captures the remote ID value
// so we can update any relationships...
var record = new SyncRecord();
record.Table_Id = "product_table";
record.Local_Id = row.Id;
record.Remote_Id = newObject.Id;
_recordRepository.Save(record);
_recordRepository.Commit();
OnUpdateStatus?.Invoke(this, new ProgressEventArgs("Synced entity " + ++count + "/" + total));
// Remove after successful remove
localTable.Remove(row);
localTable.Commit();
}
#endregion
}