node里mySQL的封装

var db = {};
var mysql = require('mysql');
var pool = mysql.createPool({
  host: 'localhost',
  user: '123456',
  password: '123456',
  database: "serve",
  multipleStatements: true
});
db.query = function () {
  var sql, para, callback;
  if (arguments.length == 2) {
    sql = arguments[0];
    callback = arguments[1];
  } else {
    sql = arguments[0];
    para = arguments[1];
    callback = arguments[2];
  }
  if (!sql) {
    callback();
    return;
  }
  if (!para) {
    para = [];
  }
  pool.query(sql, para, function (err, rows, fields) {
    if (err) {
      //console.log(err);
      callback(err, null);
      return;
    };
    callback(null, rows, fields);
  });
}

module.exports = db;

使用

let db = require('./mysql.js');
let addSql ='INSERT INTO users(Id,content,createTime) VALUES (0,?,NOW())'
 let modSqlParams = [obj.content];
      db.query(addSql, modSqlParams, function (err, result) {
        if (err) {
          console.log('[INSERT ERROR] - ', err.message);
          return;
        }
          console.log('[INSERT success] - ', result);
      });
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Express是一个流行的Node.js web应用程序框架,而MySQL是一个关系型数据库管理系统。在Express使用MySQL,我们通常需要编写一些重复的代码来连接数据库、查询数据、执行事务等等。为了避免这些重复的代码,我们可以封装一个MySQL模块,使其可以在Express应用程序重复使用。 以下是一个简单的MySQL封装模块示例: ```javascript const mysql = require('mysql'); const pool = mysql.createPool({ host: 'localhost', user: 'root', password: '', database: 'test' }); function query(sql, values) { return new Promise((resolve, reject) => { pool.getConnection((err, connection) => { if (err) { reject(err); } else { connection.query(sql, values, (err, rows) => { if (err) { reject(err); } else { resolve(rows); } connection.release(); }); } }); }); } module.exports = { query }; ``` 在这个例子,我们使用了MySQL模块来创建一个连接池,并使用Promise封装了查询方法。这个方法接受一个SQL查询语句和值的数组作为参数,并返回一个Promise对象,该对象在查询完后解析为查询结果或拒绝为错误。 我们可以将这个模块导入我们的Express应用程序,并在需要的地方调用查询方法。例如: ```javascript const express = require('express'); const mysql = require('./mysql'); const app = express(); app.get('/users', async (req, res, next) => { try { const users = await mysql.query('SELECT * FROM users'); res.json(users); } catch (err) { next(err); } }); app.listen(3000, () => { console.log('Server started on port 3000'); }); ``` 在这个例子,我们使用Express创建了一个简单的API端点,该端点从数据库检索所有用户并将其作为JSON响应发送回客户端。我们使用了async/await语法来处理异步查询,并使用try/catch块来捕获任何错误并将其传递给Express的错误处理程序。 这只是一个简单的MySQL封装示例,你可以根据你的实际需求进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

卤鸽子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值