当前位置:Gxlcms > JavaScript > 在nodejs中连接MySQL(详细教程)

在nodejs中连接MySQL(详细教程)

时间:2021-07-01 10:21:17 帮助过:5人阅读

这篇文章主要介绍了nodejs实现的连接MySQL数据库功能,结合实例形式分析了nodejs连接及查询mysql数据的相关操作步骤与实现技巧,需要的朋友可以参考下

本文实例讲述了nodejs实现的连接MySQL数据库功能。分享给大家供大家参考,具体如下:

1、在工程目录下运行npm install mysql安装用于nodejs的mysql模块;

2、创建db.js模块用于连接mysql,同时定义query查询方法;

  1. var mysql = require('mysql');
  2. // 创建一个数据库连接池
  3. var pool = mysql.createPool({
  4. connectionLimit: 50,
  5. host: 'localhost',
  6. user: 'admin',
  7. password: '123456',
  8. database: 'rp-test'
  9. });
  10. // SELECT * FROM users
  11. // 让我们的方法支持两种模式
  12. // 一种是只传入SQL语句和回调函数
  13. // 一种是传入SQL语句、参数数据、回调函数
  14. exports.query = function (sql, P, C) {
  15. var params = [];
  16. var callback;
  17. // 如果用户传入了两个参数,就是SQL和callback
  18. if (arguments.length == 2 && typeof arguments[1] == 'function') {
  19. callback = P;
  20. } else if (arguments.length == 3 && Array.isArray(arguments[1]) && typeof arguments[2] == 'function') {
  21. params = P;
  22. callback = C;
  23. } else {
  24. throw new Error('对不起,参数个数不匹配或者参数类型错误');
  25. }
  26. // 如果用户传入了三个参数,那么就是SQL和参数数组、回调函数
  27. // 从池子里面拿一个可以使用的连接
  28. pool.getConnection(function (err, connection) {
  29. // Use the connection
  30. connection.query(sql, params, function () {
  31. // 使用完毕之后,将该连接释放回连接池
  32. connection.release();
  33. callback.apply(null, arguments);
  34. });
  35. });
  36. };

3、查询示例

  1. var express = require('express');
  2. var db = require('./db');
  3. var router = express.Router();
  4. router.get('/',function(req, res, next){
  5. db.query("select * from app",function(err,result){
  6. //console.log(result);
  7. res.send(JSON.stringify (result));
  8. });
  9. });
  10. module.exports=router;

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

pace.js和NProgress.js如何使用加载进度插件(详细教程)

在微信小程序中有关App生命周期(详细教程)

在jQuery中有关NProgress.js加载进度插件使用方法

以上就是在nodejs中连接MySQL(详细教程)的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行