我有一个字节数组,其中包含例如
byte mac[6] = {0x00, 0x8a, 0x0C, 0x98, 0x11, 0x15}
.
使用此语句将其插入数据库时
m_pWiFiRecords->Fields->Item[varColumnIndex]->Value = _variant_t((char*)(pRecord->bss_id));
它将它保存为一个空数组,因为第一个元素 = 0x00,并且在将其转换为字节数组时将其保存为 -1。
你能帮我解决问题吗?
以下是将二进制数据放入 _variant_t 的方法。如果数据库设置为处理二进制数据,它应该适合您。
请注意, _variant_t 将负责在SAFEARRAY
超出范围时对其进行深度销毁,因此您不必担心会执行SafeArrayDestroy
.
_variant_t var;
var.vt = VT_ARRAY | VT_UI1;
SAFEARRAYBOUND rgsabound[1];
rgsabound[0].cElements = 6;
rgsabound[0].lLbound = 0;
var.parray = SafeArrayCreate(VT_UI1,1,rgsabound);
void * pArrayData = NULL;
SafeArrayAccessData(var.parray,&pArrayData);
memcpy(pArrayData, mac, 6);
SafeArrayUnaccessData(var.parray);
m_pWiFiRecords->Fields->Item[varColumnIndex]->Value = var;