本文实例讲述了nodejs入门教程之连接数据库的方法。分享给大家供大家参考,具体如下:
1.准备工作
在nodejs中没有MysqL模块,但npm中提供了MysqL,所以可以使用npm安装MysqL
命令:npm install MysqL, 会生成 node_modules 文件夹 ,如图
执行后发现报了一个警告,说没有package.json 这个文件,只需要执行 npm init -f 的命令就会生成一个这个文件
2.直接连接数据库
MysqL.createConnection(Object) 方法与 MysqL.createPool(Object)的参数
连接数据库
MysqL = require('MysqL'); //调用MysqL模块
//创建一个connection
var connection = MysqL.createConnection({
host: '192.168.3.3',//主机
user: 'root',//MysqL认证用户名
password: 'x5',//MysqL认证用户密码
database: 'dason_yu',port: '3306' //端口号
});
//创建一个connection
connection.connect(function(err){
if(err){
console.log('[query] - :'+err);
return;
}
console.log('[connection connect] succeed!');
});
//执行sql语句
var userAddsql = 'insert into user (id,name,money) values(?,?,?)';
var param = [3,'ccc',200];
/**
* 执行所有类型的 sql 语句
* query(sql,arr[],function)
* @parms: sql:sql语句 arr: 填充站位符的数组,可以缺省
* function: 回调函数,result: 结果集,对象组成的数组
*/
connection.query(userAddsql,param,function(err,rs){
if(err){
console.log('insert err:',err.message);
return;
}
console.log('insert success');
});
//关闭connection
connection.end(function(err){
if(err){
console.log(err.toString());
return;
}
console.log('[connection end] succeed!');
});
3.使用连接池连接数据库
使用在命令行窗口中 node httpServer.js 运行
MysqL = require('MysqL'); //用于创建数据库连接
var pool = MysqL.createPool({// 创建数据库连接池
host : '127.0.0.1',user : 'root',password : 'root',database : 'dason',multipleStatements: true
});
/**
* 获取数据库连接
* @parms: err:异常 connnection:数据库连接对象
*
*/
pool.getConnection(function(err,connection){
if(err){
console.log(err);
}
/**
* 执行所有类型的 sql 语句
* query(sql,function)
* @parms: sql:sql语句 arr: 填充站位符的数组,可以缺省
* function: 回调函数,result: 结果集,对象组成的数组
*/
connection.query('SELECT * FROM user',result){
console.log(result);
connection.release();//将连接放回连接池
});
});
结果:
4. end() 与 destroy()、release()
end() 接受一个回调函数,并且会在query结束之后才触发,如果query出错,仍然会终止链接,错误会传递到回调函数中处理。
destroy() 立即终止数据库连接,即使还有query没有完成,之后的回调函数也不会在触发。
release() 将连接放回连接池中。
5.package.json
上面代码表示单独安装express模块,
–save参数表示将该模块写入dependencies属性,
–save-dev表示将该模块写入devDependencies属性。
希望本文所述对大家nodejs程序设计有所帮助。