abrrrrrb
2021-11-16 01:26
采纳率: 100%
浏览 53

如何将已存入数据库的byte数组类型 由object类型完美还原 同原数组?

原将一个指纹录入得到的 byte数组 存入Access数据库(字段类型:OLD对象)时,数组长度为120000(数据库中显示为“长二进制数据”),再用 OleDbDataAdapter 和 DataSet 从数据库后取出该数据时,为object类型,后经网络查询,用 A 方法将该object类型还原为byte数组后,长度为256,再用 B 方法还原得到的数组长度为 54,均与原数组大相径庭,问如何才能将object对象完美还原为原数组?或者有无方法直接从数据库调回原数组?
附:A、B方法

public static byte[] A(object obj)
        {
            byte[] buff = new byte[Marshal.SizeOf(obj)];
            IntPtr ptr = Marshal.UnsafeAddrOfPinnedArrayElement(buff, 0);
            Marshal.StructureToPtr(obj, ptr, true);
            return buff;
        }
public static byte[] B(object obj)
        {
            BinaryFormatter bf = new BinaryFormatter();
            MemoryStream stream = new MemoryStream();
            bf.Serialize(stream, obj);
            byte[] datas = stream.ToArray();
            stream.Dispose();
            return datas;
        }

  • 写回答
  • 好问题 提建议
  • 追加酬金
  • 关注问题
  • 邀请回答

1条回答 默认 最新

  • CSDN专家-文盲老顾 2021-11-16 08:27
    最佳回答

    DataTable.Columns[你的二进制字段].DataType 是什么类型?

    评论
    解决 无用
    打赏 举报

相关推荐 更多相似问题