OpenFileDialog循环应用程序仅在数据库查询之后

时间:2016-03-22 18:16:45

标签: c# multithreading winforms openfiledialog

我遇到了困难:

这是我的表格:

enter image description here

第一个按钮' ...'是一个btnAllegato。代码:

        private void btnAllegato_Click(object sender, EventArgs e)
    {

        try
        {

            using (OpenFileDialog openFileDialog1 = new OpenFileDialog())
            {
                string path = string.Empty;

                openFileDialog1.Title = "Seleziona richiestaIT (PDF)..";
                openFileDialog1.Filter = ("PDF (.pdf)|*.pdf");
                openFileDialog1.FilterIndex = 1;
                openFileDialog1.FileName = "";


                if (openFileDialog1.ShowDialog() == DialogResult.OK)
                {

                    //salva l'intero path
                    path = openFileDialog1.FileName;

                    //nome file + estensione
                    string temp = openFileDialog1.SafeFileName;

                    //elimina l'estensione del file con IgnoreCase -> case Unsensitive
                    temp = Regex.Replace(temp, ".pdf", " ", RegexOptions.IgnoreCase);

                    //datatime + replace
                    string timenow = System.DateTime.Now.ToString();

                    //replace data da gg//mm/aaaa  ss:mm:hh  ----->  ad   gg-mm-aaaa_ss-mm-hh  
                    timenow = timenow.Replace(":", "-").Replace("/", "-");//.Replace(" ", " ");     

                    _url = @"\\192.168.5.7\dati\SGI\GESTIONE IT\RichiesteIT\" + temp + timenow + ".pdf";

                    System.IO.File.Copy(path, _url);
                }
            }
        }
        catch (Exception ex)
        {
            MessageBox.Show(ex.Message);
        }
    }

我有一个按钮Inserisci>> (btnInserisci) 使用此按钮i创建数据库查询以插入数据...

private void btnInserisci_Click(object sender, EventArgs e)
{
    try
    {
        if ((_IDRichiedente != -1) && (_data != string.Empty) && (_url != string.Empty))
        {
            MessageBox.Show(_url);
            QueryAssist qa = new QueryAssist();
            string query = "INSERT INTO RICHIESTA_IT(ID_Risorsa, descrizione_richiesta, modulo_pdf, data_richiesta) VALUES('" + _IDRichiedente + "', '" + txtBreveDescrizione.Text + "', '" + _url + "', '" + _data + "');";
            MessageBox.Show(query);

            qa.runQuery(query);

        else
        {
            MessageBox.Show("Selezionare il richiedente,data o allegato!");
        }
    }
    catch (Exception ex)
    {
        MessageBox.Show(ex.Message);
    }

}

其中

private int _IDRichiedente = -1;
private string _data = String.Empty;
private string _url = string.Empty;

是一个班级的领域。

QueryAssist是我的类,用于连接,运行查询和断开连接到Access DB。

代码:

    class QueryAssist
{
    System.Data.OleDb.OleDbConnection _OleDBconnection;

    public QueryAssist()
    {
        this._OleDBconnection = null;
    }



    private bool connectionDB()
    {

        string connection = "Provider=Microsoft.ACE.OLEDB.12.0; Data Source=\"\\\\192.168.5.7\\dati\\Scambio\\Sviluppo\\Impostazioni temporanea db Censimento\\CensimentoIT.accdb\"";
        try
        {
            _OleDBconnection = new System.Data.OleDb.OleDbConnection(connection);
            _OleDBconnection.Open();
            return true;

        }
        catch(Exception ex)
        {
            System.Windows.Forms.MessageBox.Show(ex.Message);
            return false;
        }
    }



    private void disconnectDB()
    {
        try
        {
            _OleDBconnection.Close();
        }
        catch (Exception ex)
        {
            System.Windows.Forms.MessageBox.Show(ex.Message);

        }
    }



    public System.Data.DataTable runQuery(string query)
    {
        try
        {
            if (connectionDB())
            {
                System.Data.DataTable dataTable = new System.Data.DataTable();
                System.Data.OleDb.OleDbCommand sqlQuery = new System.Data.OleDb.OleDbCommand(query, _OleDBconnection);
                System.Data.OleDb.OleDbDataAdapter adapter = new OleDbDataAdapter(sqlQuery);
                adapter.Fill(dataTable);
                disconnectDB();
                return dataTable;
            }
        }
        catch(Exception ex)
        {
            System.Windows.Forms.MessageBox.Show(ex.Message);
        }
        return null;

    }



    public int countRowsQueryResult(string query)
    {
        try
        {
            if (connectionDB())
            {
                System.Data.DataTable dataTable = new System.Data.DataTable();
                System.Data.OleDb.OleDbCommand sqlQuery = new System.Data.OleDb.OleDbCommand(query, _OleDBconnection);
                System.Data.OleDb.OleDbDataAdapter adapter = new OleDbDataAdapter(sqlQuery);
                adapter.Fill(dataTable);
                disconnectDB();
                return dataTable.Rows.Count;
            }
        }
        catch (Exception ex)
        {
            System.Windows.Forms.MessageBox.Show(ex.Message);
        }
        return -1;

    }
}

在第一时间......应用程序运行良好。我选择了一个文件和其他数据,然后点击按钮' Inserisci>>'一切顺利。

下一步当我要插入其他数据时...当我点击' ...'附件按钮文件我有循环OpenFileDialog enter image description here

要关闭,我必须杀死这个过程。 我在程序的主要部分设置了[STAThread]。 连接到NAS不是问题...我在本地尝试..我也遇到同样的问题..

如果我点击btn' ...'到OpenFileDialg然后不要点击按钮' Inserisci>>' OpenFileDialog一直都很好用......

但如果我点击按钮' Inserisci>>'在下一次点击按钮' ...'到OpenFileDialog应用程序循环..

抱歉英语不好..我来这里澄清

1 个答案:

答案 0 :(得分:1)

使用带有INSERT语句的runQuery方法可能是导致问题的原因。要插入记录,您应该将OleDbCommand与ExecuteNonQuery一起使用。填充方法用于填充DataTable。

无论如何插入记录的事实发生是因为用于填充DataTable(ExecuteReader)的基础命令忽略了它的sql命令文本并执行了你传递的内容。但是之后,Fill方法需要填充DataTable,而没有select语句可能是导致问题的原因。

当您需要更新/删除或插入新数据时,我会使用不同的方法

public int runNonQuery(string query)
{
    try
    {
        if (connectionDB())
        {
            OleDbCommand sqlQuery = new OleDbCommand(query, _OleDBconnection);
            int rows = sqlQuery.ExecuteNonQuery();
            disconnectDB();
            return rows;
        }
    }
    catch(Exception ex)
    {
        System.Windows.Forms.MessageBox.Show(ex.Message);
        return -1;
    }
}

您的代码中还存在其他问题,并且都与将字符串连接在一起形成sql语句的方式相关联。这被认为是数据库代码可能的最差实践。如果你花一点时间研究如何编写参数化查询,你将避免很多未来的问题。