1
從datagridview中的數據庫中獲取數據後,重複上次的數據,但遺漏了datagridview中的第一個數據。我請點擊此鏈接https://www.mindstick.com/Articles/1148/datagrid-using-backgroundworker-c-sharp在C#中使用backgroundworker在datagridview中獲取數據庫數據
private void backgroundWorker1_DoWork(object sender, DoWorkEventArgs e)
{
RetriveTableData Obj = (RetriveTableData)e.Argument;
string SqlcmdString = "SELECT * from tblBook";
SqlDataReader reader;
int i = 1;
try
{
using (SqlConnection conn = new SqlConnection(connectionString))
{
Sqlcmd = new SqlCommand(SqlcmdString, conn);
conn.Open();
reader = Sqlcmd.ExecuteReader();
if (reader.HasRows)
{
while (reader.Read())
{
//int.Parse(reader["NO_IND"].ToString());
// Obj.EmpId = reader["C_FICH"].ToString();
// Obj.EmpName = reader["C_SITE"].ToString();
Obj.AccessionNo = reader["accessionNo"].ToString();
Obj.Author = reader["author"].ToString();
Thread.Sleep(100);
// To Report progress.
backgroundWorker1.ReportProgress(i, Obj);
if (backgroundWorker1.CancellationPending)
{
// Set the e.Cancel flag so that the WorkerCompleted event
// knows that the process was cancelled.
e.Cancel = true;
backgroundWorker1.ReportProgress(0);
return;
}
i++;
}
conn.Close();
}
}
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
}
public class RetriveTableData
{
public string AccessionNo;
public string Author;
}
private void backgroundWorker1_ProgressChanged(object sender, ProgressChangedEventArgs e)
{
if (!backgroundWorker1.CancellationPending)
{
//Gets the user state that is sent as part of ReportProgress() Method from DoWork Event
RetriveTableData Obj = (RetriveTableData)e.UserState;
//Add the data to the dataGridView1
dataGridView1.Rows.Add(Obj.AccessionNo.ToString(), Obj.Author.ToString());
progressBar1.Value = e.ProgressPercentage;
label1.Text = "Processing row.. " + e.ProgressPercentage.ToString() + " of " + TotalRecords;
}
}
private int GetTotalRecords()
{
SqlConnection con;
SqlCommand cmd;
try
{
using (con = new SqlConnection(connectionString))
{
cmd = new SqlCommand("SELECT COUNT(*) FROM tblBook", con);
con.Open();
TotalRecords = int.Parse(cmd.ExecuteScalar().ToString());
con.Close();
}
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
return TotalRecords;
}
private void backgroundWorker1_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
{
if (e.Cancelled)
{
label1.Text = "Cancelled by User Intentionally...";
progressBar1.Value = 0;
}
// Check to see if an error occurred in the background process.
else if (e.Error != null)
{
label1.Text = e.Error.Message;
}
else
{
// BackGround Task Completed with out Error
label1.Text = " All Records Loaded...";
}
}
private void button1_Click(object sender, EventArgs e)
{
// statusStrip1.Visible = true;
// toolStripStatusLabel1.Visible = true;
dataGridView1.ColumnCount = 2;
dataGridView1.Columns[0].Name = "Access No.";
dataGridView1.Columns[0].Width = 150;
dataGridView1.Columns[1].Width = 150;
dataGridView1.RowHeadersWidth = 21;
dataGridView1.ColumnHeadersHeightSizeMode = DataGridViewColumnHeadersHeightSizeMode.EnableResizing;
dataGridView1.ColumnHeadersHeight = 23;
dataGridView1.Columns[1].Name = "Author";
progressBar1.Maximum = GetTotalRecords();
if (!backgroundWorker1.IsBusy)
{
RetriveTableData TObj = new RetriveTableData();
dataGridView1.Rows.Clear();
// Start the BackGround Thread to Execute
backgroundWorker1.RunWorkerAsync(TObj);
// btStart.Enabled = false;
//btCancel.Enabled = true;
}
}
我得到這個輸出,其中第一資訊:1122錯過了,重複最後一個數據PEC-5281。由於我的低級我不能張貼圖像,所以我把鏈接,你可以查看輸出。
你只有1個Obj,並且你以奇怪的方式得到它。 –
這是什麼意思。我不明白你回覆 –
你必須在while循環中創建一個新的obj。 –