自己用 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);
});

以上就是对nodejs操作mysql数据库的方法,经验总结。

nodejs 连接 mysql 查询事务处理的更多相关文章

  1. 转】用Nodejs连接MySQL

    原博文出自于: http://blog.fens.me/category/%E6%95%B0%E6%8D%AE%E5%BA%93/page/2/ 感谢! 用Nodejs连接MySQL 从零开始node ...

  2. nodejs连接mysql并进行简单的增删查改

    最近在入门nodejs,正好学习到了如何使用nodejs进行数据库的连接,觉得比较重要,便写一下随笔,简单地记录一下 使用在安装好node之后,我们可以使用npm命令,在项目的根目录,安装nodejs ...

  3. nodejs连接mysql实例

    1.在工程目录下运行npm install mysql安装用于nodejs的mysql模块: 2.创建db.js模块用于连接mysql,同时定义query查询方法: var mysql = requi ...

  4. 用Nodejs连接MySQL

    转载,原地址:http://blog.fens.me/nodejs-mysql-intro/ 前言 MySQL是一款常用的开源数据库产品,通常也是免费数据库的首选.查了一下NPM列表,发现Nodejs ...

  5. Nodejs连接mysql的增、删、改、查操作

    一,创建数据库 Source Database : my_news_test SET FOREIGN_KEY_CHECKS=0; -- ---------------------------- -- ...

  6. 使用nodejs连接mysql数据库实现增删改查

      首先要有数据库 使用xampp 或者 phpstudy 可以傻瓜式安装 新建一个项目文件夹 之后在这个目录下初始化package.json (npm init) 先在项目中安装mysql 和 ex ...

  7. Nodejs连接mysql

    1.首先需要安装nodejs 的mysql包 npm install mysql 2.编写nodejs与mysql交互的代码 var mysql = require('mysql'); var TES ...

  8. nodejs连接mysql数据库,报错Client does not support authentication protocol requested by server的解决方法

    最近想要尝试nodejs连接本地数据库,往全栈方向做一个小小的尝试,于是下载了一个 MySQL8.0,发现Navicat连接不上,结果就下载了mysql自身的Workbench,继续使用. 然而,难受 ...

  9. 使用Connector / Python连接MySQL/查询数据

    使用Connector / Python连接MySQL connect()构造函数创建到MySQL服务器的连接并返回一个 MySQLConnection对象 在python中有以下几种方法可以连接到M ...

随机推荐

  1. freeswitch编译安装依赖

    ncurses:提供字符界面 zlib:数据压缩 libjpeg:JPEG图片格式数据的解码/编码/其他. lua:lua解释器 libedit:一种编辑操作的库,对一些可以交互操作的场景,或转为了自 ...

  2. Docker安装GitLab与Runner(网关),常规设置,自动化用到k8s+token

    [转]图文详解k8s自动化持续集成之GitLab CI/CD Windows里面使用Debian命令行工具完成 和Docker网络相关的命令 查看某一个容器的网络 docker inspect 容器I ...

  3. idea鼠标双击.log日志文件无法打开

    发现只要再mybatis-config.xml的起别名中加<package name="xxx"/>,就会导致Reader entry: ����   1 n乱码,而R ...

  4. Grid 网格布局详解

    Grid网格布局详解: Grid布局与Flex布局有着一定的相似性,Grid布局是将容器划分成行和列,产生单元格,可以看做是二维布局. 基本概念: 采用网格布局的区域,称为"容器" ...

  5. 小学生都能读懂的网络协议之:WebSocket

    目录 简介 webSocket vs HTTP HTTP upgrade header websocket的优点 webScoket的应用 websocket的握手流程 WebSocket API 总 ...

  6. 用Python做了个奇奇怪怪的打篮球游戏

    一.前言 准备编写一个篮球游戏,运动员带球跑,跳起投篮.在每帧图片中包括运动员和篮球,使用多帧图片,实现运动员运球跑动的效果. 运动员运球跑动作每帧图形的宽和高可能不同,例如,跨一大步,和两腿并拢,其 ...

  7. Linux系列(14) - grep

    简述 grep是在文件当中匹配符合条件的字符串,作用是查找文件内容 格式 grep [选项] 字符串 文件名 选项 -i:忽略大小写 -v:排除指定字符串 -n:显示行号 例子 grep " ...

  8. prometheus、node_exporter设置开机自启动

    方法一.写入rc.local 在/etc/rc.local文件中编辑需要执行的脚本或者命令,我个人习惯用这个,因人而异,有的项目可能需要热加载配置文件,用服务会更好 #普罗米修斯启动,需要后面接con ...

  9. 测试验收标准checklist

    需求实现功能清单 功能实现目的 需求改造功能清单 关联功能清单 关联系统 端到端全流程场景 业务联系性场景 业务全流程场景 上下需求关联规则 业务角度在流程中关注项 财报.评级 授信方案 反洗钱 面向 ...

  10. 配置Nginx和php-fpm用Sock套接字连接时,找不到php-fpm.sock的原因

    php5.3之后的版本,php-fpm.conf里的listen的默认配置是127.0.0.1:9000,就不会生成php-fpm.sock,因此如果需要Nginx里的配置有链接tmp/php-fpm ...