Dapper Bulk Удалить, как сообщить о прогрессе - PullRequest
0 голосов
/ 21 февраля 2019

Я использую Dapper Plus, чтобы выполнить массовую вставку с использованием запроса из другой таблицы. Мой вопрос заключается в том, как один отчет о прогрессе.Как вы видите, я использую фоновый рабочий процесс для запуска своего кода, который работает нормально, однако, поскольку метод массового удаления не имеет события reportprogress, как бы я справился с этим.

public StockDeativationForm()
{
        InitializeComponent();
        this._backgroundWorker.DoWork += new DoWorkEventHandler(this.BackgroundWorkerDoWork);
        this._backgroundWorker.ProgressChanged += new ProgressChangedEventHandler(this.BackgroundWorkerProgressChanged);
        this._backgroundWorker.RunWorkerCompleted += new RunWorkerCompletedEventHandler(this.BackgroundWorkerRunWorkerCompleted);

 }

private void BackgroundWorkerDoWork(object sender, DoWorkEventArgs e)
{
     ProcessStockItems();
}

private void BackgroundWorkerProgressChanged(object sender, ProgressChangedEventArgs e)
{
        this.progressBar2.Value = e.ProgressPercentage;

 }

private void BackgroundWorkerRunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
{
        this.CompleteProcess();
 }


private void CompleteProcess()
{
        MessageBox.Show("Stock items Deleted", "Stock Item Delete", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
        base.Close();
 }

public StockDeativationForm()
{
        InitializeComponent();
        this._backgroundWorker.DoWork += new DoWorkEventHandler(this.BackgroundWorkerDoWork);
        this._backgroundWorker.ProgressChanged += new ProgressChangedEventHandler(this.BackgroundWorkerProgressChanged);
        this._backgroundWorker.RunWorkerCompleted += new RunWorkerCompletedEventHandler(this.BackgroundWorkerRunWorkerCompleted);

}

private void ProcessStockItems()
{
    string conStr = ConfigurationManager.AppSettings["DeleteStock"];
    using (var connection = new SqlConnection(conStr))
    {

      DialogResult _dialogResult = MessageBox.Show(null, "Are you sure you want to delete stock? This will delete all stock items", "Delete Stock", MessageBoxButtons.YesNo);
       if (_dialogResult == DialogResult.Yes)
       {

  connection.BulkDelete(connection.Query<StockItems>("Select ItemID FROM StockItem").ToList());
        }
     }
 }

Как один отчет возвращаетсяиспользуя этот метод массового удаления

  connection.BulkDelete(connection.Query<StockItems>("Select ItemID FROM StockItem").ToList());

1 Ответ

0 голосов
/ 22 февраля 2019

Отказ от ответственности : я владелец Dapper Plus

Вы правы,

Возможно, использование журнала может сработать?

StringBuilder log = new StringBuilder();

connection.UseBulkOptions(options => options.Log = s => {
    if(s.Contains("...xyz...")) {
        log.AppendLine(s);
    }   
}).BulkDelete(connection.Query<StockItems>("Select ItemID FROM StockItem").ToList());

Другое решение - сообщить об этом запросе в нашу службу поддержки и запросить отчет о ходе выполнения / уведомлении.

...