我在c#中创建了一个简单的项目,使用BLOB数据类型将文件数据保存到Oracle数据库中并且它可以工作。我使用devexpress gridcontrol来显示数据。这是我创建的示例数据。
btnDownload 中的将从我选择行的blob oracle下载数据。这是我的代码:
var rowHandle = gridView1.FocusedRowHandle;
var obj = gridView1.GetRowCellValue(rowHandle, "FILENAME");
if(koneksidb.con.State == ConnectionState.Open)
{
koneksidb.con.Close();
}
koneksidb.con.Open();
OracleCommand cmd = new OracleCommand();
OracleDataReader dr;
cmd.CommandText = @"SELECT * FROM LATIHANFILEMANAGER WHERE FILENAME='"+ obj +"'";
cmd.Connection = koneksidb.con;
dr = cmd.ExecuteReader();
while(dr.Read())
{
UInt32 FileSize = Convert.ToUInt32(dr.GetInt32(dr.GetOrdinal("FILESIZE"))); //get file size from table LATIHANFILEMANAGER
rawData = new byte[FileSize];
var nilai = dr.GetBytes(dr.GetOrdinal("FILEDATA"), 0, rawData, 0, (int)FileSize); //this file that i wanna download
FileStream fls = new FileStream(@"D:\newfile.png", FileMode.OpenOrCreate, FileAccess.Write);
fls.Write(rawData, 0, (int)FileSize);
fls.Close();
}
dr.Close();
当我运行这个项目并下载图像时,我得到了一个文件和文件大小但是无法打开它。
这是我捕获的文件:
我从这个链接得到的这个教程: https://docs.oracle.com/cd/E17952_01/connector-net-en/connector-net-programming-blob-reading.html
有什么建议吗?
答案 0 :(得分:0)
首先,您将图像(BLOB)从数据库显示到PictureBox,而不是使用SaveFileDialog。 欲了解更多信息,请访 How to use saveFileDialog for saving images in C#?