本文实例讲述了nodejs入门教程之连接数据库的方法。分享给大家供大家参考,具体如下:
参考文章链接: nodejs连接mysql
1.准备工作
在nodejs中没有mysql模块,但npm中提供了mysql,所以可以使用npm安装mysql
命令:npm install mysql, 会生成 node_modules 文件夹 ,如图
执行后发现报了一个警告,说没有package.json 这个文件,只需要执行 npm init -f 的命令就会生成一个这个文件
2.直接连接数据库
mysql.createConnection(Object) 方法与 mysql.createPool(Object)的参数
host 连接数据库所在的主机名. (默认: localhost) port 连接端口. (默认: 3306) localAddress 用于TCP连接的IP地址. (可选) socketPath 链接到unix域的路径。在使用host和port时该参数会被忽略. user MySQL用户的用户名. password MySQL用户的密码. database 链接到的数据库名称 (可选). charset 连接的字符集. (默认: 'UTF8_GENERAL_CI'.设置该值要使用大写!) timezone 储存本地时间的时区. (默认: 'local') stringifyObjects 是否序列化对象. See issue #501. (默认: 'false') insecureAuth 是否允许旧的身份验证方法连接到数据库实例. (默认: false) typeCast 确定是否讲column值转换为本地JavaScript类型列值. (默认: true) queryFormat 自定义的查询语句格式化函数. supportBigNumbers 数据库处理大数字(长整型和含小数),时应该启用 (默认: false). bigNumberStrings 启用 supportBigNumbers和bigNumberStrings 并强制这些数字以字符串的方式返回(默认: false). dateStrings 强制日期类型(TIMESTAMP, DATETIME, DATE)以字符串返回,而不是一javascript Date对象返回. (默认: false) debug 是否开启调试. (默认: false) multipleStatements 是否允许在一个query中传递多个查询语句. (Default: false) flags 链接标志.
连接数据库
var 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];
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.使用连接池连接数据库
将下面代码写到 httpServer.js 文件中
使用在命令行窗口中 node httpServer.js 运行
var mysql = require('mysql'); //用于创建数据库连接
var pool = mysql.createPool({// 创建数据库连接池
host : '127.0.0.1' ,
user : 'root' ,
password : 'root' ,
database : 'dason',
multipleStatements: true
});
pool.getConnection(function(err,connection){
if(err){
console.log(err);
}
connection.query('SELECT * FROM user',function(err,result){
console.log(result);
connection.release();//将连接放回连接池
});
});
结果:
[ RowDataPacket { id: 1, name: 'a', email: 'a@123' },
RowDataPacket { id: 2, name: 'b', email: 'b@123' },
RowDataPacket { id: 4, name: 'd', email: 'd@123' },
RowDataPacket { id: 5, name: 'e', email: 'e@123' },
RowDataPacket { id: 6, name: 'f', email: 'f@123' },
RowDataPacket { id: 3, name: 'c', email: 'c@123' },
RowDataPacket { id: 7, name: 'g', email: 'g@123' } ]
4. end() 与 destroy()、release()
end() 接受一个回调函数,并且会在query结束之后才触发,如果query出错,仍然会终止链接,错误会传递到回调函数中处理。
destroy() 立即终止数据库连接,即使还有query没有完成,之后的回调函数也不会在触发。
release() 将连接放回连接池中。
5.package.json
npm install express ?save
npm install express ?save-dev
上面代码表示单独安装express模块,
?save参数表示将该模块写入dependencies属性,
?save-dev表示将该模块写入devDependencies属性。
希望本文所述对大家nodejs程序设计有所帮助。