我正在开发具有线程功能的移动网络应用,需要在HTML5数据库中存储大量原始字节数据。我想将它们尽可能紧凑地存储,因此连接字符串不是一个选项。下面是一个示例代码,用于创建数据库,表,插入数据并再次检索它。
示例:
var bytes=[97, 0, 6, 244, 98, 66, 76, 65, 131, 5, 7, 142, 81, 184, 112, 33];
openDatabase('_test_', 1.0, '_test-', 5000).transaction(function(tx) {
tx.executeSql("DROP TABLE IF EXISTS MYTABLE", [], function(){
tx.executeSql("CREATE TABLE IF NOT EXISTS MYTABLE(content BLOB);",[],function(){
tx.executeSql("INSERT INTO MYTABLE values(?)", [bytes],
function()
{
tx.executeSql("SELECT * FROM MYTABLE ", [], function(transaction, results)
{
console.log(results.rows.item(0))
});
},function(transaction, error){console.log(error)})
},function(transaction, error){console.log(error)})
})
})
我正在尝试按原样存储数组,它实际上保存为连接字符串:“97,0,6,244,98,66,76,65,131,5,7,142,81,184, 112,33“。不是我需要的,因为它太大了。
我现在正在将数组转换为字符串:
openDatabase('_test_', 1.0, '_test-', 5000).transaction(function(tx) {
tx.executeSql("DROP TABLE IF EXISTS MYTABLE", [], function(){
tx.executeSql("CREATE TABLE IF NOT EXISTS MYTABLE(content BLOB); ", [], function(){
tx.executeSql("INSERT INTO MYTABLE values(?)", [s],
function()
{
tx.executeSql("SELECT * FROM MYTABLE ", [], function(transaction, results)
{
console.log(results.rows.item(0))
});
},function(transaction, error){console.log(error)})
},function(transaction, error){console.log(error)})
})
})
DB现在返回的只是“a”。
所以我的问题是如何在不使用连接字符串的情况下序列化HTML5数据库中的javascript字节数组?
答案 0 :(得分:0)
将数据转换为十六进制值并插入如下:
INSERT INTO t2 VALUES(X'53514C697465');
BLOB文字是包含十六进制数据的字符串文字,前面有一个“x”或“X”字符