使用c#从BLOB Oracle下载文件

时间:2016-03-02 08:26:08

标签: c# oracle11g devexpress blob

我在c#中创建了一个简单的项目,使用BLOB数据类型将文件数据保存到Oracle数据库中并且它可以工作。我使用devexpress gridcontrol来显示数据。这是我创建的示例数据。

enter image description here

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();

当我运行这个项目并下载图像时,我得到了一个文件和文件大小但是无法打开它。

这是我捕获的文件:

enter image description here

我从这个链接得到的这个教程: https://docs.oracle.com/cd/E17952_01/connector-net-en/connector-net-programming-blob-reading.html

有什么建议吗?

1 个答案:

答案 0 :(得分:0)

首先,您将图像(BLOB)从数据库显示到PictureBox,而不是使用SaveFileDialog。 欲了解更多信息,请访 How to use saveFileDialog for saving images in C#?