oracle 读取blob类型数据,读取Oracle中的Blob字段生成对应的文件

读取WMF的Blob字段,生成wmf文件

///

/// 读取WMF字段,生成临时WMF文件

///

private void ReadWMFBlobField()

{

OracleConnection _connection = new OracleConnection(m_connectionString);

try

{

_connection.Open();

OracleCommand _selectCommand = _connection.CreateCommand();

OracleTransaction _transaction = _selectCommand.Connection.BeginTransaction();

_selectCommand.Transaction = _transaction;

string _selectSQL = "Select WMF from hSUSEr.ZDT where ZDNO = '"

+ m_zoneNo + "'";

_selectCommand.CommandText = _selectSQL;

OracleDataReader _dataReader = _selectCommand.ExecuteReader();

if (_dataReader.Read() == true)

{

OracleLob _oracleLob = _dataReader.GetOracleLob(0);

long _byteCount = _oracleLob.Length;

_dataReader.Close();

if (File.Exists(m_wmfFileName) == true)

{

File.Delete(m_wmfFileName);

}

FileStream _fileStream = File.Open(m_wmfFileName, FileMode.OpenOrCreate);

int _length = 30485760;

byte[] _buffer = new byte[_length];

int i = _oracleLob.Read(_buffer, 0, _length);

while (i > 0)

{

_fileStream.Write(_buffer, 0, i);

i = _oracleLob.Read(_buffer, 0, _length);

}

_fileStream.Close();

_oracleLob.Close();

_selectCommand.Parameters.Clear();

_transaction.Commit();

}

else

{

MessageBoxEx.Show("没有查找到相符合的记录!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);

}

}

catch (Exception ex)

{

MessageBoxEx.Show(ex.Message, "错误", MessageBoxButtons.OK, MessageBoxIcon.Error);

}

}

读取DWG的Blob字段,生成DWG文件

///

/// 读取DWG字段,生成DWG文件

///

private void ReadDWGBlobField()

{

OracleConnection _connection = new OracleConnection(m_connectionString);

try

{

_connection.Open();

OracleCommand _selectCommand = _connection.CreateCommand();

OracleTransaction _transaction = _selectCommand.Connection.BeginTransaction();

_selectCommand.Transaction = _transaction;

string _selectSQL = "Select DWG from hsuser.ZDT where ZDNO = '"

+ m_zoneNo + "'";

_selectCommand.CommandText = _selectSQL;

OracleDataReader _dataReader = _selectCommand.ExecuteReader();

if (_dataReader.Read() == true)

{

OracleLob _oracleLob = _dataReader.GetOracleLob(0);

long _byteCount = _oracleLob.Length;

_dataReader.Close();

if (File.Exists(m_dwgFileName) == true)

{

File.Delete(m_dwgFileName);

}

FileStream _fileStream = File.Open(m_dwgFileName, FileMode.OpenOrCreate);

int _length = 30485760;

byte[] _buffer = new byte[_length];

int i;

while ((i = _oracleLob.Read(_buffer, 0, _length)) > 0)

{

_fileStream.Write(_buffer, 0, i);

}

_fileStream.Close();

_oracleLob.Clone();

_selectCommand.Parameters.Clear();

_transaction.Commit();

}

else

{

MessageBoxEx.Show("没有查找到相符合的记录!", "提示",

MessageBoxButtons.OK, MessageBoxIcon.Information);

}

}

catch (Exception ex)

{

MessageBoxEx.Show(ex.Message, "警告", MessageBoxButtons.OK, MessageBoxIcon.Error);

}

}0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值