服务器环境变了调用mysql模块总报错
发布于 7 年前 作者 vini123 3114 次浏览 来自 问答

刚接触node.js,想请教下大家一个问题,描述如下。

服务器以前的环境是 php5.6 + mysql5 ,而现在的环境是 ** php7.1 + mariadb10 **。以前调用mysql模块,存储数据都ok,现在却不行了。

服务器环境变化后,nodejs中mysql模块怎么处理呢。谢谢。

2 回复

node.js的mysql模块比较多,有mysql,mysqli,还有mariasql以及node-mariadb等。针对服务器的环境,使用对应的模块。因此,踩过不少坑。

环境差异

服务器装的mysql环境,php7或php7以下

安装对应模块:

npm install mysql  // php7以下
npm install mysqli // php7

使用:

const mysql = require('mysql');

// First you need to create a connection to the db
const con = mysql.createConnection({
  host: 'localhost',
  user: 'user',
  password: 'password',
  database: 'lovenode'
});

con.connect((err) => {
  if(err){
    console.log('Error connecting to Db');
    return;
  }
  console.log('Connection established');
});

con.end((err) => {
  // The connection is terminated gracefully
  // Ensures all previously enqueued queries are still
  // before sending a COM_QUIT packet to the MySQL server.
});

或使用连接池

const mysql = require('mysql');
const pool = mysql.createPool({
		host:'localhost',
		user:'root',
		password:'11111111',
		database:'lovenode'
});

const query = function(dbname, sql , callBack)
{
	pool.getConnection(function(error , conn){
		if(error)
		{
			callBack(error , null , null);
		}
		else
		{
			conn.query(sql , function(qerror , vals , fields){
				conn.release();
				callBack(qerror , vals , fields);
			});
		}
	});
}
module.exports = query;

然后在其他模块调query方法就可以了。

服务器装的mariadb

安装对应模块:

npm install mariasql  
npm install node-mariadb 

使用请参考:
https://npm.runkit.com/mariasql

https://yarnpkg.com/en/package/connect-mariasql

参考

https://www.sitepoint.com/using-node-mysql-javascript-client/

https://www.npmjs.com/package/connect-mariasql

https://www.npmjs.com/package/node-mariadb

https://mariadb.com/kb/en/the-mariadb-library/mariasql-for-nodejs/

node关php啥事?如果不想用orm 直接用这个好了 https://www.npmjs.com/package/mysql 就是你贴的第一个 报错的话请贴上具体错误内容。

回到顶部