我第一次使用 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