日韩欧美国产精品免费一二-日韩欧美国产精品亚洲二区-日韩欧美国产精品专区-日韩欧美国产另-日韩欧美国产免费看-日韩欧美国产免费看清风阁

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

C#Winform窗體應用程序中查詢數據庫時報錯問題分析

admin
2025年1月19日 14:42 本文熱度 519
執行長時間任務查詢數據庫,那么可能會出現一個問題:在執行長時間任務的過程中,如果點擊了進度條中的“取消”按鈕,此時可以停止程序執行查詢數據庫的任務,但是如果再次執行該任務時,可能會報錯:“連接未關閉,連接的當前狀態為打開”。

下面以一個簡單的示例來看看出現上面所述問題的原因所在。
首先,用access創建一個數據庫文件database.mdb,并保存在C#項目的bin\debug文件夾中。創建一個數據表TestData,在數據表里設置一個自增字段、一個姓名字段,一個年齡字段。
仍然使用上一篇文章中所創建窗體和類,只把DataOperate.cs這個類修改一下,改成以下的代碼,用于模擬耗時的數據庫讀取任務:
 
using System;
using System.ComponentModel;
using System.Data.OleDb;
using System.Data;
using System.IO;
using System.Threading;

namespace Test
{
    internal class DataOperate
    {
        private static String StrConn;
        private static OleDbConnection conn;
        private static OleDbCommand sc;

        public void operating(BackgroundWorker worker)
        {
            ConnectDatabase();
            for (int i = 0; i < 10; i++)
            {
                Thread.Sleep(1000);  //暫停1秒,模擬耗時的數據庫操作
                operate("insert into TestData(姓名,年齡) values('全棧開發的碼農',3)");
                worker.ReportProgress(i*100/10);
            }
        }
       
        private void ConnectDatabase()
        {
            //連接數據庫
            StrConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Directory.GetCurrentDirectory() + @"\database.mdb; " + "Persist Security Info=True;Jet OLEDB:Database Password=123456";
            try
            {
                conn = new OleDbConnection(StrConn);
            }
            catch (System.Data.SqlClient.SqlException ex)
            {
                throw new Exception(ex.Message);
            }
        }

        private void operate(String strsql)//插入、刪除、更新等數據庫操作
        {
            conn.Open();
            sc = new OleDbCommand();
            sc.CommandText = strsql;
            sc.Connection = conn;
            Thread.Sleep(1000);  //暫停1秒,模擬耗時的數據庫操作
            sc.ExecuteNonQuery();
            conn.Close();
        }

        public void close()  //關閉數據庫連接
        {
            if (conn.State == ConnectionState.Open)
            {
                conn.Close();
                conn.Dispose();
            }
        }

    }
}
此時,點擊主窗體中的“開始”按鈕,開始執行任務,往數據庫里的TestData數據表插入記錄,程序運行正常。執行到一半的時候,點擊進度條窗體中的“取消”按鈕,此時任務被取消。此時,如果再次點擊主窗體中的“開始”按鈕,出現“連接未關閉”的報錯。
經分析,問題出現在OleDbConnection對象conn上,在DataOperate.cs類中,把OleDbConnection對象conn定義成static靜態對象,這對于一般的數據庫操作是沒有問題的,因為每一個數據庫執行方法中都有conn.open()和conn.close(),數據連接可以正常打開和正常關閉,而當使用了Backgroundworker對象進行進度報告時,中途突然中斷數據庫查詢操作,那么會導致conn.close()無法正常執行,使得連接依然處于打開狀態,下一次嘗試再次連接時就出現了“連接未關閉”的報錯。
解決問題的最簡單粗暴的方法就是把static刪除,使conn成為一個普通的非靜態變量即可。這是因為static對象在程序運行的全過程中只能有一個實例,第一次執行數據庫操作時,它已經實例化,再次執行數據庫操作時,也只能使用它,不能再次實例化,而它沒有被正常關閉連接,所以再次嘗試連接數據庫時會出現“連接未關閉”的情況,而如果采用了非靜態變量,那么就相當于給conn對象重新實例化,用一個全新的完全不同于此前的實例來操作數據庫,這樣就不會報錯了。


閱讀原文:原文鏈接


該文章在 2025/1/21 9:36:19 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 亚洲精品在线免费观看 | 在线中文字幕有码中文 | 一区二区三区视频免费 | 国产精品亚洲午夜不卡 | 中文中幕a在线 | 夜夜国产亚洲视频香蕉 | 水蜜桃国产在线观看免费视频 | 一日本道伊 | 想要大鸡 | 精品国产爽香蕉在线观看 | 免费免费麻辣 | 国产女主播精 | 国产毛多女人精品视频影院 | 国产爽片大全免费在线观看 | 伦理电影在线观看 | 天天综合网天天做天天受 | 国产综合一区二区在线观看 | 亚洲国产日韩欧美一区二区三区 | 亚洲伦理一区二区 | 国产日韩在线亚洲字幕中文 | 最新免费电影在线播放 | 国产高清不卡一区二区 | 欧美日韩一区 | 欧美亚洲日本在线播放 | 国产在线精品一区二区高清 | 国产精品一级婬片免费 | 国产精品视频 | 日韩精品首页 | 国产精品美女一区二区三区 | 欧美一区二区制服在线 | 日本在线视频一区二区三区 | 91精品亚洲国 | 最新全网影视大全电影电视剧 | x8x8国产在线最新地址 | 亚洲大片精品永久免费看网站 | 国产不卡在线观看视频 | 国产精品日本一区二区在线播 | 两性色午夜视频 | 深夜影院 | 精品人伦一区二区三区蜜 | 国产精品亚洲精品日韩已满 |