0

我制作了一个项目,该项目使用 sqlserverce 数据库存储价格表、员工信息等,以 PDF 格式提供报价并打开新电子邮件以将其发送给客户。

第一个问题是:“指定的表不存在。[XXXXX]”。我发现如果我以管理员身份运行项目,它有助于连接数据库。

但这会导致其他问题:在打开 Outlook 时以管理员身份运行项目(关闭 Outlook 时没有问题):

 System.Runtime.InteropServices.COMException Retrieving the COM class factory for component with CLSID ..... (Exception from HRESULT: 0x80080005 (CO_E_SERVER_EXEC_FAILURE)).

当项目尝试创建新电子邮件时。

是否有任何解决方法或方法可以使两个部分一起工作?你有线索吗?我用谷歌搜索了一下,但我了解到我必须更改注册表以避免第二个问题。还有其他方法吗?

这是电子邮件的代码:

Outlook.Application objApp = new Outlook.Application();
              Outlook.MailItem mail = null;
              mail = (Outlook.MailItem)objApp.CreateItem(Outlook.OlItemType.olMailItem);
              //The CreateItem method returns an object which has to be typecast to MailItem 
              //before using it.
              mail.Attachments.Add((object)saveFile.FileName, Outlook.OlAttachmentType.olByValue, 1, Type.Missing);
              //The parameters are explained below
              mail.To = email;
              mail.BCC = "someemailshere@something.pl";
              mail.Display();

这是数据库连接的代码(在程序中发生了几次):

 System.Data.SqlServerCe.SqlCeConnection sqlconnection = new System.Data.SqlServerCe.SqlCeConnection();
  System.Data.DataSet DtSet = new System.Data.DataSet();
  System.Data.SqlServerCe.SqlCeDataAdapter sqladapter;
  string katalog = Application.StartupPath + "\\Bazadanych.sdf"; //Data Source = C:\\Users\\user\\Documents\\Visual Studio 2010\\Projects\\BMGRP\\Oferty BMGRP\\Oferty BMGRP\\bin\\Debug\\BazaDanych.sdf

  sqlconnection.ConnectionString = "Data Source = " + katalog + "; Max Database Size=40"; //zmienić na katalog root programu
  sqlconnection.Open();

  string sql = "SELECT * From Przedstawiciele";
  sqladapter = new System.Data.SqlServerCe.SqlCeDataAdapter(sql, sqlconnection);


  sqladapter.Fill(DtSet);
  comboBox1.DataSource = DtSet.Tables[0];
  comboBox1.DisplayMember = "imie";

  sqlconnection.Close();

是的。该程序默认安装在程序文件中。

4

1 回答 1

0

其他研究表明,不可能做我想做的事情(以管理员身份运行项目并在 Outlook 开启时创建电子邮件)。因此,唯一的解决方案是解决数据库问题:将应用程序安装在其他文件夹中,然后按照@spender 的建议安装程序文件。它有帮助。

于 2014-01-20T20:24:49.407 回答