本人在做一个新闻内容的模块的时候,发现如果内容在4K以上的字符串会出错,得到的内容会是乱码(也就是被自动截断),如果小于4K,那么就不会有问题。 原来采用了Varchar2的类型来存储,但发现后修改为Clob类型的也出现同样的问题,而且发现日志的错误是:System.Data.OracleClient.OracleException: ORA-01461: can bind a LONG value only for insert into a LONG column。 由于Clob类型是可以存放很大类型的文本数据的,不会是数据库字段容量不够,因此检查插入和更新的C#代码,发现原来的代码是这样的: 代码 public bool Insert(Hashtable recordField, string targetTable, DbTransaction trans) { bool result = false; string fields = ""; // 字段名 string vals = ""; // 字段值 if ( recordField == null || recordField.Count < 1 ) { return result; } List<OracleParameter> paramList = new List<OracleParameter>(); IEnumerator eKeys = recordField.Keys.GetEnumerator(); while ( eKeys.MoveNext() ) { string field = eKeys.Current.ToString(); fields += field + ","; if (!string.IsNullOrEmpty(seqField) && !string.IsNullOrEmpty(seqName) && (field.ToUpper() == seqField.ToUpper())) { vals += string.Format("{0}.NextVal,", seqName); } else { vals += string.Format(":{0},", field); object val = recordField[eKeys.Current.ToString()]; paramList.Add(new OracleParameter(":" + field, val)); } } fields = fields.Trim(",");//除去前后的逗号 vals = vals.Trim(",");//除去前后的逗号 string sql = string.Format("INSERT INTO {0} ({1}) VALUES ({2})", targetTable, fields, vals); Database db = DatabaseFactory.CreateDatabase(); DbCommand command = db.GetSqlStringCommand(sql); command.Parameters.AddRange(paramList.ToArray()); if ( trans != null ) { result = db.ExecuteNonQuery(command, trans) > 0; } else { result = db.ExecuteNonQuery(command) > 0; } return result; } 重要的地方就是我使用了该行代码: paramList.Add(new OracleParameter(":" + field, val)); 猜想可能是由于这行代码的问题导致,因此修改参数化的Oracle参数变量代码为另外一个种指定对象类型的方式: OracleParameter a = new OracleParameter(":" + field, OracleType.Clob, val.ToString().Length); a.Value = val; paramList.Add(a);
Oracle承诺继续支持Sparc和Solaris Sun老用户倍感鼓舞Oracle的物化视图管理相关资讯 oracle
- [INS-32052] Oracle基目录和Oracle (07/22/2014 07:41:41)
- Oracle 4个大对象(lobs)数据类型 (02/03/2013 12:33:05)
- Oracle按时间段分组统计 (07/26/2012 10:36:48)
| - [Oracle] dbms_metadata.get_ddl的 (07/12/2013 07:37:30)
- Liferay Portal 配置使用Oracle和 (07/31/2012 20:07:18)
- Concurrent Request:Inactive (07/20/2012 07:44:05)
|
本文评论 查看全部评论 (0)