node如何连接mysql并进行增删改查和事务操作
Admin 2022-07-05 群英技术资讯 1019 次浏览
本篇内容介绍了“node如何连接mysql并进行增删改查和事务操作”的有关知识,在实际项目的操作过程或是学习过程中,不少人都会遇到这样的问题,接下来就让小编带大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!nodejs连接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 事务处理
我们直接步入正题,使用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);
});
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
同步与异步fs中 带Sync的就是同步方式 不带的就是异步在这先对同步和异步进行区别同步:前面的代码先执行 后面的代码需要等待前面的代码执行完毕才会执行异步:代码的执行不
JS是由ES(ECMAScript)、DOM(浏览器文档对象)、BOM(浏览器对象模型)组成,这篇文章主要给大家介绍了关于如何使用ES6的class类继承来实现绚丽小球效果的相关资料,需要的朋友可以参考下
这篇文章主要介绍了vue3+typeScript穿梭框的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
怎样用React实现有动态效果的弹窗组件?对于实现一个简单的弹窗组件还是比较简单的,但是本文给大家分享的带有动态效果的,也就是在弹出弹窗的时候有动效展示。下面我们就来看看怎样实现。
中国省市区三级联动Jquery插件经常被使用到,不管是网站还是app,这个都是需要掌握的,我们知道中国省市区三级联动的数据可以存储在mysql数据库中,也可以直接存储在distpicker.data.js这样的js文件中,下面来开始学习如何使用Jquery省市区三级联动插件。 下
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008