ODP.net for 10G, 数据提供方内部错误(-3000)

sunj_study 2008-03-26 02:23:54
基于Oracle提供的ODP.net类库,做Oracle数据库操作。程序开始运行正常,在运行一段时间后(几小时),出现如下错误:
Number=-3000
Message=数据提供方内部错误(-3000)
Source=Oracle Data Provider for .NET
DataSource=test
引发该错误的操作为查询数据库中的某条记录。记录中包含BLOB类型字段。

SQL操作如下:
byte[] data;
string strSql = "select data from test where id = "+id;
OracleCommand cmd = new OracleCommand(strSql, db);
OracleDataReader reader = cmd.ExecuteReader();
if (reader.Read())
{
if (!reader.IsDBNull(0))
{
data = reader.GetOracleBlob(0).Value;
}
else
{
data = null;
}
}
reader.Close();
...全文
334 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
sunj_study 2008-04-01
  • 打赏
  • 举报
回复
问题解决。
解决方法:升级ODP.net开发库。由10.1.0.200 升级到10.1.0.400。
sunj_study 2008-03-27
  • 打赏
  • 举报
回复
多谢CathySun118 帮忙。

咱俩用的类库不一样,没有可比性。

初步估计是类库的使用方法不当引起的这个错误。在性能比较好的机器上不出现上述错误。
CathySun118 2008-03-27
  • 打赏
  • 举报
回复
给你个方法参考:
string conn_str = "Provider=OraOLEDB.Oracle.1;Password=agoodjob;Persist Security Info=True;User ID=ams;Data Source=ims;Extended Properties=";//Provider必須用OraOLEDB.Oracle.1

OleDbDataAdapter da = new OleDbDataAdapter();
DataSet ds = new DataSet();
OleDbConnection conn = new OleDbConnection(conn_str);
OleDbCommand cmd = new OleDbCommand("SELECT PHOTO FROM WEB_DB.USERS WHERE USER_ID = 1", conn);
da.SelectCommand = cmd;
cmd.Connection.Open();
da.Fill(ds);

byte[] img = new byte[0];
DataRow dr;
dr = ds.Tables[0].Rows[0];

if (!ds.Tables[0].Rows[0]["PHOTO"].ToString().Equals(""))
{
img = (byte[])dr["PHOTO"];
}

Response.ContentType= "image/*";
Response.BinaryWrite (img);

conn.Close();

17,086

社区成员

发帖
与我相关
我的任务
社区描述
Oracle开发相关技术讨论
社区管理员
  • 开发
  • Lucifer三思而后行
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧