javascript - 错误 : Could not locate the bindings file better-sqlite3. Node

标签 javascript node.js sqlite node-gyp better-sqlite3

问题

可能我安装的 better-sqlite3 有一些问题,因为当我尝试执行我的 index.js 时(单击以在 pastebin 上显示)与

Node 索引.js

结果总是一样的。我在 MacOS 上试过,它可以工作,但在我的机器上基于 Linux Lite Ubuntu 的发行版不是它给了我以下相同的错误:

/home/mp8/webproject/electron-better-sqlite/node_modules/bindings/bindings.js:96
  throw err
  ^

Error: Could not locate the bindings file. Tried:
 → /home/mp8/webproject/electron-better-sqlite/node_modules/better-sqlite3/build/better_sqlite3.node
 → /home/mp8/webproject/electron-better-sqlite/node_modules/better-sqlite3/build/Debug/better_sqlite3.node
 → /home/mp8/webproject/electron-better-sqlite/node_modules/better-sqlite3/build/Release/better_sqlite3.node
 → /home/mp8/webproject/electron-better-sqlite/node_modules/better-sqlite3/out/Debug/better_sqlite3.node
 → /home/mp8/webproject/electron-better-sqlite/node_modules/better-sqlite3/Debug/better_sqlite3.node
 → /home/mp8/webproject/electron-better-sqlite/node_modules/better-sqlite3/out/Release/better_sqlite3.node
 → /home/mp8/webproject/electron-better-sqlite/node_modules/better-sqlite3/Release/better_sqlite3.node
 → /home/mp8/webproject/electron-better-sqlite/node_modules/better-sqlite3/build/default/better_sqlite3.node
 → /home/mp8/webproject/electron-better-sqlite/node_modules/better-sqlite3/compiled/8.11.3/linux/x64/better_sqlite3.node
    at bindings (/home/mp8/webproject/electron-better-sqlite/node_modules/bindings/bindings.js:93:9)
    at Object.<anonymous> (/home/mp8/webproject/electron-better-sqlite/node_modules/better-sqlite3/lib/database.js:4:40)
    at Module._compile (module.js:652:30)
    at Object.Module._extensions..js (module.js:663:10)
    at Module.load (module.js:565:32)
    at tryModuleLoad (module.js:505:12)
    at Function.Module._load (module.js:497:3)
    at Module.require (module.js:596:17)
    at require (internal/module.js:11:18)
    at Object.<anonymous> (/home/mp8/webproject/electron-better-sqlite/node_modules/better-sqlite3/index.js:2:18)

我的目的是什么?

我想使用 better-sqlie33 作为我的数据库,因为 sqlite3 不支持 Node 8.x 及更高版本。

我尝试了什么:

  1. 此故障排除指南编号 one and two , 但我仍然有同样的错误。

  2. make init,第一次安装 better-sqlite3 给我错误文件 make/makefile not found。当我执行 npm install better-sqlite3 --save

  3. 时,我遇到了同样的错误
  4. 确保 better_sqlite3.node 在我的 node-modules 路径上。是的,它不在那里。

我想要什么?

我想运行我的 index.js就像我在 Mac 上运行它一样正确。

依赖

package.json after make init, if not it just a better-sqlite3 dependencies

{
  "_from": "better-sqlite3",
  "_id": "better-sqlite3@4.1.4",
  "_inBundle": false,
  "_integrity": "sha512-Y11HN9PQ9YUeKFMrmiHyOLAKElk2ATJzBZJvuzNwTMxoS7vUEEyLnUCtcBFqViLwbomr0RQwp2MBy/ogxF50PA==",
  "_location": "/better-sqlite3",
  "_phantomChildren": {},
  "_requested": {
    "type": "tag",
    "registry": true,
    "raw": "better-sqlite3",
    "name": "better-sqlite3",
    "escapedName": "better-sqlite3",
    "rawSpec": "",
    "saveSpec": null,
    "fetchSpec": "latest"
  },
  "_requiredBy": [
    "#USER",
    "/"
  ],
  "_resolved": "https://registry.npmjs.org/better-sqlite3/-/better-sqlite3-4.1.4.tgz",
  "_shasum": "9fe1dcf7b699087b98b1997cbb00261e265897e2",
  "_spec": "better-sqlite3",
  "_where": "/home/mp8/webproject/electron-better-sqlite",
  "author": {
    "name": "Joshua Wise",
    "email": "joshuathomaswise@gmail.com"
  },
  "bugs": {
    "url": "https://github.com/JoshuaWise/better-sqlite3/issues"
  },
  "bundleDependencies": false,
  "dependencies": {
    "bindings": "^1.3.0",
    "integer": "^1.0.5"
  },
  "deprecated": false,
  "description": "The fastest and simplest library for SQLite3 in Node.js.",
  "devDependencies": {
    "benchmark": "^2.1.4",
    "chai": "^4.1.2",
    "cli-color": "^1.2.0",
    "fs-extra": "^5.0.0",
    "mocha": "^4.1.0",
    "sqlite": "^2.9.0"
  },
  "gypfile": true,
  "homepage": "http://github.com/JoshuaWise/better-sqlite3",
  "keywords": [
    "sql",
    "sqlite",
    "sqlite3",
    "custom",
    "aggregate",
    "database",
    "transactions"
  ],
  "license": "MIT",
  "name": "better-sqlite3",
  "repository": {
    "type": "git",
    "url": "git://github.com/JoshuaWise/better-sqlite3.git"
  },
  "scripts": {
    "benchmark": "node benchmark",
    "install": "node-gyp rebuild",
    "install-debug": "node-gyp rebuild --debug",
    "lzz": "lzz -hx hpp -sx cpp -k BETTER_SQLITE3 -d -hl -sl -e ./src/better_sqlite3.lzz",
    "posttest": "rm -r ./temp/",
    "prepublishOnly": "npm run lzz",
    "pretest": "rm -r ./temp/ || true && mkdir ./temp/",
    "rebuild": "npm run lzz && node-gyp rebuild",
    "rebuild-debug": "npm run lzz && node-gyp rebuild --debug",
    "test": "$(npm bin)/mocha --bail --timeout 5000 --slow 5000"
  },
  "version": "4.1.4"
}

my machine

Linux Lite 4.0, Ubuntu Based.
NVM (Node version Manager)
Node 8.11.1
NPM 5.6

最佳答案

我有一个问题看起来像你的问题

试试看:

projectToto > $ sudo rm -rf node_modules/

projectToto > $ npm 安装绑定(bind)

关于绑定(bind)的 npm -> https://www.npmjs.com/package/bindings

关于javascript - 错误 : Could not locate the bindings file better-sqlite3. Node ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50997956/

相关文章:

javascript - ES6 导入和 node_modules hell

android - SQLiteOpenHelper onCreate()/onUpgrade() 什么时候运行?

javascript - 如何将 Javascript 变量传递到 HTML 文件中

node.js - 查询结果达到 500+ 后,Mongoose find 查询与 populate 在 Azure MongoDB 上返回错误

javascript - 从 json 响应创建列表菜单

javascript - Node.js Http 服务器,readstream 结束事件触发 console.log 两次

android - 在 SQLite 数据库中使用 bool 值

c# - 与 SQLite/SubSonic(或任何其他数据库)一起使用时,避免在项目中使用 App.config 文件

javascript - 使用 JavaScript 访问 "animate"我的网页

在页面显示之前加载 Javascript 警报