问题可能出在sql.js 和test.sqlite 文件的位置。如果将它们保存在同一目录中,请将名称写为 './sql.js' './test.sqlite' 并带有点和斜线:
var fs = require('fs');
var SQL = require('./sql.js');
var data = fs.readFileSync('./Chinook_Sqlite.sqlite');
var sqldb = new SQL.Database(data);
我只是运行上面的代码,它在 Node.js (node test.js) 上运行良好。我的目录有以下文件:
- test.js - 来自上述示例的文件
- sql.js - 库文件
- Chinook_Sqlite.sqlite - Chinook 测试数据库
更新 2 来自 SQL.js 的人员建议在最新版本的 SQL.js 中使用此代码(请参阅 SQL.js wiki):
var xhr = new XMLHttpRequest();
xhr.open('GET', '/path/to/database.sqlite', true);
xhr.responseType = 'arraybuffer';
xhr.onload = function(e) {
var uInt8Array = new Uint8Array(this.response);
var db = new SQL.Database(uInt8Array);
var contents = db.exec("SELECT * FROM my_table");
// contents is now [{columns:['col1','col2',...], values:[[first row], [second row], ...]}]
};
xhr.send();
UPDATE 1 如果需要在浏览器中打开 SQLite 文件,可以使用下面的代码(参见工作示例here):
<script src="sql.js"></script>
<script>
function loadBinaryFile(path,success) {
var xhr = new XMLHttpRequest();
xhr.open("GET", path, true);
xhr.responseType = "arraybuffer";
xhr.onload = function() {
var data = new Uint8Array(xhr.response);
var arr = new Array();
for(var i = 0; i != data.length; ++i) arr[i] = String.fromCharCode(data[i]);
success(arr.join(""));
};
xhr.send();
};
loadBinaryFile('./Chinook_Sqlite.sqlite', function(data){
var sqldb = new SQL.Database(data);
// Database is ready
var res = db.exec("SELECT * FROM Genre");
});
</script>