我目前正在开展一个项目。文档存储库系统。我使用C#windows窗体和MS Access 2010作为我的数据库。我的文档存储表名为“文档”,有2列,即项目ID和文件(附件数据类型)。我现在可以使用openfiledialog浏览文件,但似乎无法上传它。
以下是我上传按钮的当前代码。
con = new OleDbConnection(cs);
con.Open();
String num = lblPnum.Text.ToString();
string a = "INSERT INTO [Documents]([ProjectID]) VALUES('"+ num + "')";
cmd = new OleDbCommand(a);
cmd.Connection = con;
cmd.ExecuteReader();
con.Close();
MessageBox.Show("Document Successfully Added", "Prompt", MessageBoxButtons.OK, MessageBoxIcon.Information);
this.Close();
FrmHome home = new FrmHome();
home.Show();
home.statusPanel.Text = statusPanel.Text;
截至目前,我已经可以根据我选择的项目编号获取项目ID。我需要添加什么才能将文件附加到我的数据库并将其显示到gridview。
答案 0 :(得分:0)
您可以在MS Access中上传类似文件,请记住特定数据库位于应用程序的Debug文件夹中,Access数据库的名称为 DB
try
{
FileInfo file = new FileInfo("file.xlsx");
using (var connection1 = new OleDbConnection(@"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=DB.mdb"))
{
OleDbCommand cmd = new OleDbCommand();
//SqlDataAdapter cmd = new SqlDataAdapter();
using (cmd = new OleDbCommand("INSERT INTO simple (doc) values (@file)", connection1))
{
//cmd.Connection = connection1;
connection1.Open();
cmd.CommandType = CommandType.Text;
cmd.Parameters.AddWithValue("@file", file);
cmd.ExecuteNonQuery();
}
}
}
catch (Exception ex)
{
}
答案 1 :(得分:0)
处理Access附件类型需要Microsoft Access 14.0对象库
。示例代码如下。
private void insertImageFileToMemo(String memoId)
{
var dbe = new DBEngine();
Database db = dbe.OpenDatabase(@"D:\yourdatabase.accdb");
try
{
Recordset rstMain = db.OpenRecordset(
"SELECT memoId,memoImage FROM MyMemo WHERE MemoID = '" + memoId + "'",
RecordsetTypeEnum.dbOpenDynaset);
rstMain.Edit();
Recordset2 rstAttach = rstMain.Fields["memoImage"].Value;
rstAttach.AddNew();
Field2 fldAttach = (Field2)rstAttach.Fields["FileData"];
fldAttach.LoadFromFile("memofile1.jpg");
rstAttach.Update();
rstAttach.Close();
rstMain.Update();
rstMain.Close();
}
catch (Exception ex)
{
Console.WriteLine(ex.ToString());
}
}
答案 2 :(得分:0)
Microsoft Docs 上的这篇文章有一个工作示例:Work with attachments in DAO
var dbe = new DBEngine();
Database db = dbe.OpenDatabase(DBFilePath, ReadOnly: false);
// first record set is the table
Recordset rs = db.OpenRecordset("SELECT * FROM " + TableName);
rs.MoveFirst();
rs.Edit();
// second record set is the actual field / cell in the table
Recordset2 rs2 = (Recordset2)rs.Fields["Attachments"].Value;
// add document
rs2.AddNew();
Field2 f2 = (Field2)rs2.Fields["FileData"];
f2.LoadFromFile(ImageFile);
rs2.Update();
rs2.Close();
rs.Update();
rs.Close()