我制作了一个项目,该项目使用 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();
是的。该程序默认安装在程序文件中。