c# – 如何更新BLOB列,错误ORA-00932,而Insert工作
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了c# – 如何更新BLOB列,错误ORA-00932,而Insert工作,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2733字,纯文字阅读大概需要4分钟。
内容图文
![c# – 如何更新BLOB列,错误ORA-00932,而Insert工作](/upload/InfoBanner/zyjiaocheng/788/416a419bd01e4465977b2a6ceb528e8d.jpg)
我无法更新BLOB字段,但Insert工作,请参阅下面的代码.
我的猜测是它与在大量记录中存储一个BLOB值的问题有关,涉及复制大数据.
就我而言,我知道只会更新一条记录,但Oracle可能认为可能需要更新几条记录.使用Insert,保证只涉及1条记录,但并不总是使用Update.现在我该如何解决这个问题?
注意:Where子句中的ArtNr字段是具有唯一索引的主键.
顺便说一句,我发现在互联网上插入BLOB有很多代码示例,但我找不到更新BLOB的代码示例.
using Oracle.DataAccess.Client;//needs reference to Oracle.DataAccess.dll
using Oracle.DataAccess.Types; //OracleBlob
public static bool StoreBlobImage(OracleConnection conn, string ArtNr, byte[] bImageJpg)
{
bool Ok = false;
#if true // this is what I need, but does not work
string Sql = "update MyTable set Image = :Image where ArtNr = :ArtNr";
#else // this works
string Sql = "insert into MyTable (ArtNr, Image) values (:ArtNr, :Image)";
#endif
using (OracleCommand cmd = new OracleCommand(Sql, conn))
{
//cmd.Connection = conn;
//cmd.CommandType = CommandType.Text;
cmd.Parameters.Add("ArtNr", OracleDbType.Varchar2, 8).Value = ArtNr;
#if false // tried method 1
cmd.Parameters.Add("Image", OracleDbType.Blob).Value = bImageJpg;
#else // now trying method 2
OracleParameter blobParameter = new OracleParameter();
blobParameter.OracleDbType = OracleDbType.Blob;
blobParameter.ParameterName = "Image";
blobParameter.Value = bImageJpg;
blobParameter.Direction = ParameterDirection.Input;
blobParameter.IsNullable = true;
cmd.Parameters.Add(blobParameter);
#endif
try
{
conn.Open();
cmd.ExecuteNonQuery(); // ORA-00932: inconsistent datatypes: expected - got BLOB
}
catch (Exception TheException)
{
}// debug breakpoint
}
return Ok;
}
解决方法:
我在阅读你的帖子时,我确实想到了什么.出于好奇,我尝试了它并且惊讶于这个错误确实发生了.
有好消息.我戳了一下,发现了这个:
How can I update data in CLOB fields using a >> prepared query << with ODP (Oracle.DataAccess)?
当使用带有LOB的update语句时,必须首先在参数中声明LOB.考虑到这一点,我得到了与您的代码相同的错误,但这完美地工作:
public static bool StoreBlobImage(OracleConnection conn, string ArtNr, byte[] bImageJpg)
{
bool Ok = false;
string Sql = "update MyTable set Image = :Image where ArtNr = :ArtNr";
using (OracleCommand cmd = new OracleCommand(Sql, conn))
{
cmd.Parameters.Add("Image", OracleDbType.Blob).Value = bImageJpg;
cmd.Parameters.Add("ArtNr", OracleDbType.Varchar2, 8).Value = ArtNr;
try
{
cmd.ExecuteNonQuery();
}
catch (Exception TheException)
{
}
}
return Ok;
}
只需切换参数即可.
我对原始问题的问答(同样的人,在这种情况下)给了一个关键.
你是对的,网上有很少的东西可以帮助你更新Oracle中的BLOB.
好问题.我觉得我今天学到了一些东西.
– 编辑 –
根据OP的建议,根据上面引用的相同线程,还有另一个修复,可以防止重新排列参数的必要性.我的猜测是,如果要更新多个LOB,这可能会派上用场.
切换BindByName属性似乎也解决了问题:
cmd.BindByName = true;
内容总结
以上是互联网集市为您收集整理的c# – 如何更新BLOB列,错误ORA-00932,而Insert工作全部内容,希望文章能够帮你解决c# – 如何更新BLOB列,错误ORA-00932,而Insert工作所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。