OracleOracle中对细长内容的处理,防止出现can bind a LONG value only for insert into a LONG column错误

自作者在做二个谍报内容的模块的时候,发现只要剧情在4K之上的字符串会出错,获得的始末会是乱码(也便是被电动截断),借使低于4K,那么就不会失常。

原先选拔了Varchar二的类型来储存,但发现后修改为Clob类型的也应运而生同样的标题,而且发现日志的不当是:System.Data.OracleClient.OracleException:
ORA-01四陆一: can bind a LONG value only for insert into a LONG column。

是因为Clob类型是足以存放十分大体系的公文数据的,不会是数据库字段体量不够,由此检查插入和翻新的C#代码,发现原来的代码是那样的:

 Oracle 1代码

        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));
                }
            }

            田野(field)s = 田野(field)s.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参数类型,正是为了适应各体系型对象的参数化构造,完结合并添加参数化内容的,由于超长的字符内容会产出难题,因而只可以修改基类操作的增加参数代码,添加1个原则分支作为处理。调整后的插入代码如下(更新代码类似操作):

 Oracle 2代码

        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()];

                    if (val.ToString().Length >= 4000)
                    {
                        OracleParameter a = new OracleParameter(“:” + field, OracleType.Clob, val.ToString().Length);
                        a.Value = val;
                        paramList.Add(a);
                    }
                    else
                    {
                        paramList.Add(new OracleParameter(“:” + field, val));
                    }
                }
            }

            田野(field)s = 田野同志s.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;
        }

 

 

 那样,就可以在动用代码生成工具Database二Sharp(http://www.iqidi.com/database2sharp.htm)生成的Oracle代码中,不需要改变任何地方,只需要调整BaseDAL的基类中Insert和Update中的部分内容,就可以了。

 

 

相关文章