我刚刚开始接触Node.js。我来自PHP背景,所以我相当习惯使用MySQL来满足我的所有数据库需求。
我如何使用MySQL与Node.js?
我刚刚开始接触Node.js。我来自PHP背景,所以我相当习惯使用MySQL来满足我的所有数据库需求。
我如何使用MySQL与Node.js?
当前回答
您还可以尝试一种名为Node.js DB的新方法,该方法旨在为多个数据库引擎提供一个通用框架。它是用c++构建的,因此性能得到了保证。
具体来说,你可以使用它的db-mysql驱动程序来支持Node.js的MySQL。
其他回答
在我看来,你应该尝试MySQL Connector/Node.js,这是MySQL的官方Node.js驱动程序。 详见ref-1和ref-2。 我尝试了mysqljs/mysql,这里是可用的,但我没有找到这个库的类,方法,属性的详细文档。
所以我切换到标准的MySQL Connector/Node.js和X DevAPI,因为它是一个异步的基于承诺的客户端库,并提供了良好的文档。 看一下下面的代码片段:
const mysqlx = require('@mysql/xdevapi');
const rows = [];
mysqlx.getSession('mysqlx://localhost:33060')
.then(session => {
const table = session.getSchema('testSchema').getTable('testTable');
// The criteria is defined through the expression.
return table.update().where('name = "bar"').set('age', 50)
.execute()
.then(() => {
return table.select().orderBy('name ASC')
.execute(row => rows.push(row));
});
})
.then(() => {
console.log(rows);
});
KnexJs可以在Node.JS和浏览器中用作SQL查询构建器。 我发现它很容易使用。让我们试试它- Knex.js
$ npm install knex --save
# Then add one of the following (adding a --save) flag:
$ npm install pg
$ npm install sqlite3
$ npm install mysql
$ npm install mysql2
$ npm install mariasql
$ npm install strong-oracle
$ npm install oracle
$ npm install mssql
var knex = require('knex')({
client: 'mysql',
connection: {
host : '127.0.0.1',
user : 'your_database_user',
password : 'your_database_password',
database : 'myapp_test'
}
});
你可以这样用
knex.select('*').from('users')
or
knex('users').where({
first_name: 'Test',
last_name: 'User'
}).select('id')
因为这是一个旧线程,只是添加了一个更新:
安装MySQL node.js驱动程序:
如果你只是运行npm install mysql,你需要在运行服务器的同一个目录下。我建议按照下面的例子来做:
全球安装:
npm install -g mysql
本地安装:
1-把它添加到你的包里。Json的依赖项:
"dependencies": {
"mysql": "~2.3.2",
...
2-运行NPM install
注意,为了建立连接,你还需要运行mysql服务器(它是独立于节点的)
安装MySQL服务器:
有很多教程解释了这一点,它有点依赖于操作系统。只要去谷歌搜索如何安装mysql服务器[Ubuntu|MacOSX|Windows]。但一句话:你必须去http://www.mysql.com/downloads/并安装它。
查看node.js模块列表
node-mysql -一个实现MySQL协议的node.js模块 node-mysql2 -另一个纯JS异步驱动程序。流水线,准备好的语句。 node-mysql-libmysqlclient -基于libmysqlclient的MySQL异步绑定
Node-mysql看起来很简单:
var mysql = require('mysql');
var connection = mysql.createConnection({
host : 'example.org',
user : 'bob',
password : 'secret',
});
connection.connect(function(err) {
// connected! (unless `err` is set)
});
查询:
var post = {id: 1, title: 'Hello MySQL'};
var query = connection.query('INSERT INTO posts SET ?', post, function(err, result) {
// Neat!
});
console.log(query.sql); // INSERT INTO posts SET `id` = 1, `title` = 'Hello MySQL'
node-mysql可能是用于MySQL数据库的最好的模块之一,它是积极维护和良好的文档。