1

我第一次使用 SQL Compact 4.0 并尝试将数据插入到 IMAGE 列中,并且大部分数据约为 50kbytes。

我遇到的问题是,虽然图像列应该足够大,但数据被截断为 8000 字节。

我正在使用 SqlCeParameter 插入数据。大小已设置为匹配 byte[] (43402) 的长度,并且 SqlDbType 为 SqlDbType.Image。

在数据库中,您可以看到所有行都是 8000 字节(使用 datalength 函数)。

我怀疑这是数据库架构本身的东西,也许是为 IMAGE 列设置的默认大小,我希望可以覆盖它。有趣的是,该参数具有基础 DbType.Binary - 根据 Microsoft 的规定,它限制为 8000 字节 - 可能是红鲱鱼!

====

因为我无法添加任何图像,grrrr。以下是更多信息:

这是我构建命令的代码。_params 只是一个字典,其中包含每个参数名称和数据:

var cmd = connection.CreateCommand();
cmd.CommandText = _command;

foreach(var p in _params)
{
  var param = SqlHelper.CreateSqlCeParameter(p);
  cmd.Parameters.Add(param);
  if(param.SqlDbType == System.Data.SqlDbType.Image)
  {
     param.Size = (p.Value as byte[]).Length;
  }
}
cmd.ExecuteNonQuery();

使用这个帮助类来创建参数:

public class SqlHelper
    {
        public static SqlDbType MapToSqlCeType(object data)
        {
            if(data.GetType() == typeof(string))
            {
                return SqlDbType.NVarChar; 
            }

            if(data.GetType() == typeof(byte[]))
            {
                return SqlDbType.Image;
            }

            return SqlDbType.NVarChar;
        }

        internal static SqlCeParameter CreateSqlCeParameter(KeyValuePair<string, object> data)
        {
            return new SqlCeParameter(data.Key, SqlHelper.MapToSqlCeType(data.Value))
            {
                Value = data.Value
            };
        }
    }

我用来检查的 SQL: SELECT top 10 datalength([Data]) FROM [Datamodule]; 去

结果: Column1 8000 8000 8000 8000 8000 8000 8000 8000 8000 8000

4

1 回答 1

0

我想通了,这是我创建 SqlCeParameter 的方式的问题。

如果我只是使用名称和值构建参数,则 SqlDbType 设置为 VarBinary(默认情况下),这会将所有数据插入 IMAGE 类型列。

因此,使用以下代码可以正常工作:

 var cmd = connection.CreateCommand();
                    cmd.CommandText = _command;

                    foreach (var p in _params)
                    {
                        cmd.Parameters.Add(new SqlCeParameter(p.Key, p.Value));
                    }

                    cmd.ExecuteNonQuery();

VarBinary 似乎没有将 SqlDbType 显式设置为 Image,而是完成了这项工作。我之前曾尝试通过脚本升级数据库并将数据转换/转换为 VARBINARY 已将其截断为 4000 字节,这就是我首先走这条路的原因。

谢谢您的帮助。

于 2015-08-10T08:34:57.070 回答