node连接mysql查询事务处理的实现

 更新时间:2021年11月02日 10:35:12   作者:阿政想暴富  
本文主要介绍了node连接mysql查询事务处理的实现,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

自己用 mysql 很多次的,然后又是主玩nodejs的.专门写一篇文章来说说nodejs连接mysql数据库。在使用之前,请检查计算机是否具有一下环境!

  • nodejs 执行环境。
  • mysql数据库环境(下载地址)。
  • navicat 连接 mysql 数据库的图形化操作软件。(非必要)

进入正题 mysql 增删改查

首先,我们去下载一个叫mysql的依赖包,这个包就是通过 nodejs 代码去连接数据库,从而操作数据库。

创建一个文件夹,快速生成pakeage.json文件

D:\nodejs_mysql>npm init -y  # 快速传创建包管理文件

安装依赖

D:\nodejs_mysql>npm i mysql -D # 安装mysql 依赖包

创建一个 index.js 文件,代码如下

const mysql = require("mysql");

// 创建 一个mysql 连接池
const pool = mysql.createPool({
  host: "127.0.0.1", // 连接数据库的地址 127.0.0.1 为本地的mysql
  user: "root", //  连接数据库的用户名 root 是最高权限
  password: "", //  连接数据库的密码
  database: "apm", // 操作的数据库名
  port: "3306", // 连接mysql的端口号
  multipleStatements: true, // 运行一次执行多条sql语句 可以忽略此项
});

function select() {
  // 请求连接mysql
  pool.getConnection((err, connection) => {
    // 未连接成功 报错
    if (err) throw err;
    // 得到一个 连接对象 调用 query 方法 可以执行 sql 语句
    let sql = "select * from goods";
    // 运行sql语句 query 第二个参数为 sql语句需要的参数 ,没有可以不写
    connection.query(sql, (errors, results, fields) => {
      // 释放连接
      connection.release();
      // 如果运行sql语句有报错 抛出错误
      if (errors) throw errors;
      console.log(results);
      console.log(fields);
    });
  });
}

select();

以上的代码是查询 数据库apm一个数据表goods的数据。results为从数据库取出的数据。

封装方法 使用Promise来查询数据库

//  index.js
// ... 忽略前面的创建mysql连接池代码
function query(sql, params) {
  return new Promise((resolve, reject) => {
    pool.getConnection((err, connection) => {
      // 未连接成功 报错
      if (err) return reject(err);
      // 得到一个 连接对象 调用 query 方法 可以执行 sql 语句
      // 运行sql语句 query 第二个参数为 sql语句需要的参数 ,没有可以不写
      connection.query(sql, params, (errors, results, fields) => {
        // 释放连接
        connection.release();
        // 如果运行sql语句有报错 抛出错误
        if (errors) return reject(errors);
        resolve(results);
      });
    });
  });
}

query("select * from goods", null).then((result) => {
  console.log(result);
});
module.exports = {
  query,
};

使用

// data.js
const index = require("./index.js");
var sql = "select * from goods";
index
  .query(sql, null)
  .then((result) => {
    // do anything ....
  })
  .catch((err) => {
    // error
    console.log(err);
  });

这样就向外暴露了一个数据库运行 sql 的接口。通过promise使用.then这种链式调用的代码风格。

mysql 事务处理

说到 mysql 事务,我也就不做过多介绍了,这里给个友情链接方便大家学习。MySQL 事务处理

我们直接步入正题,使用promise来封装 mysql 的事务处理.

// index.js

// .... 部分创建 pool 的代码

/**
 * mysql 事务处理
 * @param {Array} sqls 需要执行的sql语句
 * @param {Array} params 对应上面sql语句的参数
 * @returns {Promise} 返回一个Promise
 */
function transaction(sqls, params) {
  return new Promise((resolve, reject) => {
    pool.getConnection(function (err, connection) {
      // 连接失败 promise直接返回失败
      if (err) {
        return reject(err);
      }
      // 如果 语句和参数数量不匹配 promise直接返回失败
      if (sqls.length !== params.length) {
        connection.release(); // 释放掉
        return reject(new Error("语句与传值不匹配"));
      }
      // 开始执行事务
      connection.beginTransaction((beginErr) => {
        // 创建事务失败
        if (beginErr) {
          connection.release();
          return reject(beginErr);
        }
        console.log("开始执行事务,共执行" + sqls.length + "条语句");
        // 返回一个promise 数组
        let funcAry = sqls.map((sql, index) => {
          return new Promise((sqlResolve, sqlReject) => {
            const data = params[index];
            connection.query(sql, data, (sqlErr, result) => {
              if (sqlErr) {
                return sqlResolve(sqlErr);
              }
              sqlReject(result);
            });
          });
        });
        // 使用all 方法 对里面的每个promise执行的状态 检查
        Promise.all(funcAry)
          .then((arrResult) => {
            // 若每个sql语句都执行成功了 才会走到这里 在这里需要提交事务,前面的sql执行才会生效
            // 提交事务
            connection.commit(function (commitErr, info) {
              if (commitErr) {
                // 提交事务失败了
                console.log("提交事务失败:" + commitErr);
                // 事务回滚,之前运行的sql语句不生效
                connection.rollback(function (err) {
                  if (err) console.log("回滚失败:" + err);
                  connection.release();
                });
                // 返回promise失败状态
                return reject(commitErr);
              }

              connection.release();
              // 事务成功 返回 每个sql运行的结果 是个数组结构
              resolve(arrResult);
            });
          })
          .catch((error) => {
            // 多条sql语句执行中 其中有一条报错 直接回滚
            connection.rollback(function () {
              console.log("sql运行失败: " + error);
              connection.release();
              reject(error);
            });
          });
      });
    });
  });
}
module.exports = {
  transaction,
};

之后只需要调用这个方法就可以执行 mysql 事务了

// data.js
const index = require("./index.js");
var sqls = [
  "delete from goods where goods_id = ?", // 删除 语句
  "update goods set num = ? where goods_id = ?;", // 更新语句
];
var params = [
  [1], // parmas 是数组格式 与sqls里的sql语句里 ? 一一对应
  [5, 3],
];

index
  .transaction(sqls, params)
  .then((arrResult) => {
    // do anything ....
  })
  .catch((err) => {
    // error
    console.log(err);
  });

到此这篇关于node连接mysql查询事务处理的实现的文章就介绍到这了,更多相关node连接mysql查询事务处理内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • express中static中间件的具体使用方法

    express中static中间件的具体使用方法

    这篇文章主要介绍了express中static中间件的具体使用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10
  • 从零开始学习Node.js系列教程之基于connect和express框架的多页面实现数学运算示例

    从零开始学习Node.js系列教程之基于connect和express框架的多页面实现数学运算示例

    这篇文章主要介绍了Node.js基于connect和express框架的多页面实现数学运算,简单讲述了connect和express框架的原理及数学运算相关操作技巧,需要的朋友可以参考下
    2017-04-04
  • node.js实现简单的压缩/解压缩功能示例

    node.js实现简单的压缩/解压缩功能示例

    这篇文章主要介绍了node.js实现简单的压缩/解压缩功能,结合实例形式分析了node.js实现本地文件与服务器端压缩/解压缩相关操作技巧,需要的朋友可以参考下
    2019-11-11
  • node.js中的Socket.IO使用实例

    node.js中的Socket.IO使用实例

    这篇文章主要介绍了node.js中的Socket.IO使用实例,本文讲解了Socket.IO的安装、结合express来构建服务器、基本使用方法及一个网络聊天室的完整案例,需要的朋友可以参考下
    2014-11-11
  • Node.js+Express+Mysql 实现增删改查

    Node.js+Express+Mysql 实现增删改查

    这篇文章主要介绍了Node.js+Express+Mysql 实现增删改查,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • node.js中使用ejs渲染数据的代码实现

    node.js中使用ejs渲染数据的代码实现

    这篇文章主要介绍了node.js中使用ejs渲染数据,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2023-11-11
  • node.js事件轮询机制原理知识点

    node.js事件轮询机制原理知识点

    在本篇文章里小编给大家分享的是一篇关于node.js事件轮询机制的相关知识点文章,有兴趣的朋友们可以参考下。
    2019-12-12
  • Node.js中的events事件模块知识点总结

    Node.js中的events事件模块知识点总结

    在本篇文章里小编给大家整理的是一篇关于Node.js中的events事件模块知识点总结内容,有兴趣的朋友们可以跟着学习下。
    2021-12-12
  • Node.js的路由、EJS模板引擎、GET和POST请求讲解

    Node.js的路由、EJS模板引擎、GET和POST请求讲解

    这篇文章介绍了Node.js的路由、EJS模板引擎、GET和POST请求,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06
  • node.js缺少mysql模块运行报错的解决方法

    node.js缺少mysql模块运行报错的解决方法

    前几天在工作中需要利用node.js连接数据库,通过网上的教程连接后运行却报错了,然后赶紧查找解决的方法,通过测试与朋友的提点,终于解决了这个问题,现在将解决的方法分享给大家,有需要的朋友们可以参考借鉴,下面来一起看看吧。
    2016-11-11

最新评论