使用MySQLConnector / Net的FatalExecutionEngineError

时间:2013-04-18 13:59:39

标签: c# mysql visual-studio-2010

我正在开发一个连接到MySQL数据库的C#.NET应用程序,并使用一些不安全的代码来使用旧的C ++ DLL。

一旦程序启动,它将加载dll并分配一个指针,然后它将初始化一些C#变量,然后删除指针。

在程序中,我有一个对话框,里面有一个标签控件。这个“对话框”的构造函数从使用旧dll和DB初始化的变量中获取数据,并在此处启动问题:

        Dictionary<String, int> dizUM;
        MySqlCommand            myCom;
        MySqlConnection         myConn;
        MySqlDataReader         myRead;

        cmbRigheCons.Items.Add( MosaicoS.Properties.Resources.STR_CONS_DESC_GEN );
        cmbRigheCons.Items.Add( MosaicoS.Properties.Resources.STR_CONS_TIP_SOTT );
        cmbRigheCons.Items.Add( MosaicoS.Properties.Resources.STR_CONS_SOTT );
        cmbRigheCons.Items.Add( MosaicoS.Properties.Resources.STR_CONS_NOM_PEZ_CONS );
        cmbRigheCons.SelectedIndex = MosaicoMain.CFG.DescCons;
        cmbRigheVarMat.Items.Add( MosaicoS.Properties.Resources.STR_CONS_DESC_GEN );
        cmbRigheVarMat.Items.Add( MosaicoS.Properties.Resources.STR_CONS_TIP_SOTT );
        cmbRigheVarMat.Items.Add( MosaicoS.Properties.Resources.STR_CONS_SOTT );
        cmbRigheVarMat.Items.Add( MosaicoS.Properties.Resources.STR_CONS_NOM_PEZ_CONS );
        cmbRigheVarMat.Items.Add( MosaicoS.Properties.Resources.STR_CONS_NOM_PEZ_NEL_CONS );
        cmbRigheVarMat.SelectedIndex = MosaicoMain.CFG.DescVarMat;
        try
        {
            string connessione;

            connessione = MosaicoMain.CFG.DBConnection.Replace( "Option=3;", "" );
            connessione = connessione.Replace( "Driver={MySQL ODBC 5.1 Driver};", "" );
            myConn = new MySqlConnection( connessione );
            myCom = new MySqlCommand();
            myConn.Open();
            myCom.Connection = myConn;
            myCom.CommandText = @"SELECT umi_id, umi_um FROM unimis WHERE umi_tipoum = 0 ORDER BY umi_um;";
            myRead = myCom.ExecuteReader();
            dizUM = new Dictionary<String, int>();
            while( myRead.Read() )
                dizUM.Add( myRead.GetString( 1 ), myRead.GetInt32( 0 ) );
            cmbUMSup.DataSource = new BindingSource( dizUM, null );
            cmbUMSup.DisplayMember = "Key";
            cmbUMSup.ValueMember = "Value";
            myRead.Close();
            myConn.Close();
        }
        catch( MySqlException mySqlException )
        {
            MessageBox.Show( mySqlException.ToString() );
        } 

如果我从myConn.Open()发表评论;到myConn.Close();我没有遇到麻烦,但打开连接会导致程序几乎立即崩溃当我在表格之间切换时,但不是在程序的这一部分而是在:

    private void configurazioniToolStripMenuItem1_Click( object sender, EventArgs e )
    {
        try
        {
            frmConfig = new FrmConfigurazioni();
            frmConfig.ShowDialog();
        }
        catch( Exception exception )
        {
            MessageBox.Show( exception.ToString() );
        }
    }

这是我加载前一个代码段的地方。 错误是:

Managed Debugging Assistant 'FatalExecutionEngineError' has detected a problem in 
'C:\DEVELOP\MosaicoS\MosaicoS\bin\Debug\MosaicoS.vshost.exe'.
Additional Information: The runtime has encountered a fatal error. 
The address of the error was at 0x792380d9, on thread 0x824. 
The error code is 0xc0000005. 
This error may be a bug in the CLR or in the unsafe or non-verifiable portions of user code. 
Common sources of this bug include user marshaling errors for COM-interop or PInvoke, which may corrupt the stack.

并且是一个例外。如果我评论代码,我也不会遇到崩溃,如果我尝试用同一个字符串连接到另一个解决方案中的同一个数据库,我没有遇到任何问题。 我该如何解决这个问题?

提前致谢。

1 个答案:

答案 0 :(得分:1)

'0xc0000005'是访问冲突异常。很难找到你提供的代码有什么问题。我建议找到旧c ++ dll的源代码,并在一个解决方案中一起调试它们。您可以通过选中.net项目属性中Debug部分下的“启用非托管代码调试”复选框,从.net调试c ++ dll。