node如何连接mysql并进行增删改查和事务操作
Admin 2022-07-05 群英技术资讯 679 次浏览
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进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
目录vue实现Toast轻提示首先创建一个toast组件在js文件中引入组件在入口文件中引入上面这个js文件下面就可以在view里全局使用了使用vant的Toast轻提示报错文档中是这样写的实际使用是这样写vue实现Toast轻提示首先创建一个toast组件template div class=context v-s
Element UI 是 PC 端比较流行的 Vue.js UI 框架,它的组件库基本能满足大部分常见的业务需求。但有时候会有一些定制性比较高的需求,组件本身可能没办法满足。最近在项目里就碰到了。
这篇文章给大家分享的是有关JS怎样做弹窗消息动画的效果的内容,小编觉得挺实用的,因此分享给大家做个参考,实现效果及代码如下,接下来一起跟随小编看看吧。
这篇文章主要介绍了 JavaScript 与 TypeScript之间的联系,JavaScript,也称为 JS,是一种符合 ECMAScript 规范的编程语言。这是一个高级别的、通常是即时编译的、多范式的。TypeScript 是一种强类型、面向对象的编译语言,更多消息内容,需要的朋友可以参考一下下面文章内容
jQuery如何停止函数执行,用什么语句?终止某个函数执行是很常见的需求,jQuery中我们可以使用函数来实现,下面我们具体的来看看是怎样做的,希望对大家学习jQuery的使用有帮助。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008