我无法更新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;
}
答案 0 :(得分:3)
我在阅读你的帖子时,我确实想到了什么。出于好奇,我尝试了它并且惊讶于这个错误确实发生了。
有好消息。我戳了一下,发现了这个:
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;