nodejs入门教程五:连接数据库的方法分析

前端之家收集整理的这篇文章主要介绍了nodejs入门教程五:连接数据库的方法分析前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

本文实例讲述了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)的参数

数据库所在的主机名. (默认: localhost)链接到unix域的路径。在使用host和port时该参数会被忽略.MysqL用户用户名.MysqL用户的密码.链接到的数据库名称 (可选).方法连接到数据库实例. (默认: false)自定义的查询语句格式化函数.数据库处理大数字(长整型和含小数),时应该启用 (默认: false).查询语句. (Default: false)链接标志.

连接数据库

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.使用连接池连接数据库

将下面代码写到 httpServer.js 文件

使用在命令行窗口中 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程序设计有所帮助。

猜你在找的Node.js相关文章