node.js中对 mysql 进行增删改查等操作和async,await处理

要对mysql进行操作,我们需要安装一个mysql的库。

一、安装mysql库

npm install mysql --save

  

二、对mysql进行简单查询操作

const mysql = require('mysql');

//创建数据库连接
let conn = mysql.createConnection({
    //主机地址
    host: '127.0.0.1',//用户名
    user: 'root',//密码
    password: '123456',//数据库
    database: 'test',//端口
    port: 3306,//字符集
    charset: 'utf8'
});

//连接数据库
conn.connect(function (err) {
    if (err) {
        throw err;
    }
    console.log('连接成功');
});

//查询数据库
conn.query('select * from tb_user',function (err,data,field) {
    if (err) {
        throw err;
    }
    //data表示结果集数据,是一个数组
    console.log(data);
    data.forEach(function (value) {
        console.log(value.id,value.user_name,value.addr);
    });
    //表字段的详细信息
    console.log(field);
});

//关闭数据库连接
conn.end();

  

二、对mysql进行增删改操作

const mysql = require('mysql');

//创建数据库连接
let conn = mysql.createConnection({
    //主机地址
    host: '127.0.0.1',//字符集
    charset: 'utf8'
});

//连接数据库
conn.connect(function (err) {
    if (err) {
        throw err;
    }
    console.log('连接成功');
});

//插入数据,query()方法可以对sql语句进行参数绑定,用?号作为占位符。
conn.query('insert into tb_user values(null,?,?)',['xxx','xxx'],data) {
    if (err) {
        throw err;
    }
    if (data && data.affectedRows) {
        console.log('插入数据成功,id为',data.insertId);
    }
});

//修改数据
conn.query('update tb_user set user_name = ? where id = ?',['ggg',7],data) {
    if (err) {
        throw err;
    }
    if (data && data.affectedRows) {
        console.log('修改数据成功');
    }
});

//删除数据
conn.query('delete from tb_user where id = ?',[5],data) {
    if (err) {
        throw err;
    }
    if (data && data.affectedRows) {
        console.log('删除数据成功');
    }
});

//关闭数据库连接
conn.end();

  

三、使用mysql连接池来优化对数据库的操作

频繁的连接和断开mysql是比较消耗资源的,我们可以创建一个连接池,复用连接池中的连接,提高效率。

const mysql = require('mysql');

//创建数据库连接池
let pool = mysql.createPool({
    //连接数量,默认是10
    connectionLimit: 20,//主机地址
    host: '127.0.0.1',//字符集
    charset: 'utf8'
});

//pool.query()方法可以自动的帮我们在连接池中获取可用连接
pool.query('select * from tb_user',data) {
    if (err) {
        throw err;
    }
    data.forEach(function (value) {
        console.log(value.id,value.addr);
    });
});

//当然我们也可以手动获取可用连接
pool.getConnection(function (err,conn) {
    if (err) {
        throw err;
    }
    conn.query('select * from `order`',data) {
        if (err) {
            throw err;
        }
        data.forEach(function (value) {
            console.log(value.id,value.order_id,value.user_id);
        });

        //连接用完之后,需要释放,重新放回连接池中。
        //注意这里并没有销毁该连接,该连接仍然可用,但需要重新获取
        conn.release();
    });
});

//从连接池中获取连接时,将触发该事件
pool.on('acquire',function (conn) {
    console.log('获取连接',conn.threadId);
});

//在连接池中建立新连接时,将触发该事件
pool.on('connection',function (conn) {
    console.log('建立新连接',conn.threadId);
});

//等待可用连接时,将触发该事件
pool.on('enqueue',function () {
    console.log('等待可用连接');
});

//当连接释放回池中时,触发该事件
pool.on('release',function (conn) {
    console.log('连接被释放回池中',conn.threadId);
});

//结束池中所有的连接,不然node.js的事件循环会一直保持
setTimeout(function () {
    pool.end(function (err) {
        console.log('关闭连接池');
        console.log(err);
    });
},3000);

  

四、按流的方式进行查询

const mysql = require('mysql');

//创建数据库连接
let conn = mysql.createConnection({
    //主机地址
    host: '127.0.0.1',//字符集
    charset: 'utf8'
});

let query = conn.query('select * from tb_user');
//Query类继承自Sequence,而Sequence继承自EventEmitter
//所以Query类的实例是可以监听事件

//发生错误时
query.on('error',function (err) {
    console.log(err);
});

//获取查询字段信息
query.on('fields',function (fields) {
    console.log(fields);
});

//获取查询结果
query.on('result',function (result) {
    //暂停获取结果
    conn.pause();
    //跟流的pause()和resume()很类似,控制获取数据的频率。
    setTimeout(function () {
        console.log(result);
        //恢复获取结果
        conn.resume();
    },1000);
});

//查询结束
query.on('end',function () {
    console.log('查询结束');
});

conn.end();

通过query.stream()方法返回一个可读流来获取数据

const mysql = require('mysql');

//创建数据库连接
let conn = mysql.createConnection({
    //主机地址
    host: '127.0.0.1',//字符集
    charset: 'utf8'
});

//从一个查询中获取一个可读流
let qs = conn.query('select * from tb_user').stream({highWaterMark: 2});

let result = [];
qs.on('data',function (data) {
    result.push(data);
});

qs.on('end',function () {
    console.log('查询结束');
    console.log(result);
});

conn.end();

  

五、mysql的事务处理

const mysql = require('mysql');

//创建数据库连接
let conn = mysql.createConnection({
    //主机地址
    host: '127.0.0.1',//字符集
    charset: 'utf8'
});

//连接数据库
conn.connect(function (err) {
    if (err) {
        throw err;
    }
    console.log('连接成功');
});

//开启一个事务
conn.beginTransaction(function (err) {
    if (err) {
        throw err;
    }
    conn.query('update account set money = money - 50 where name = ?',['A'],data) {
        if (err) {
            //如果有错误则回滚
            return conn.rollback(function () {
                throw err;
            });
        }
        conn.query('update account set money = money + 50 where name = ?',['B'],data) {
            if (err) {
                //如果有错误则回滚
                return conn.rollback(function () {
                    throw err;
                });
            }
            //提交事务
            conn.commit(function (err) {
                if (err) {
                    //如果有错误则回滚
                    return conn.rollback(function () {
                        throw err;
                    });
                }
                console.log('处理成功');
                conn.end();
            });
        });
    });
});

  

六、解决mysql嵌套回调的问题

有些时候我们的操作需要上一个操作的结果,这样会导致比较深的嵌套问题,为了解决可以使用async和await来解决,而async和await又是基于promise的。

const mysql = require('mysql');

//创建数据库连接
let conn = mysql.createConnection({
    //主机地址
    host: '127.0.0.1',//字符集
    charset: 'utf8'
});

function query(conn,sql,params = []) {
    if (!conn) {
        return;
    }
    return new Promise(function (resolve,reject) {
        conn.query(sql,params,data) {
            if (err) {
                reject(err);
            } else {
                resolve(data);
            }
        });
    });
}

(async function () {
    let result = await query(conn,'select * from tb_user');
    console.log(result);
    let row = await query(conn,'select * from tb_user where id = ?',[result[0].id]);
    console.log(row);
    conn.end();
})();

当然我们还可以使用 util.promiseify() 进行包装。

const mysql = require('mysql');
const util = require('util');

//创建数据库连接
let conn = mysql.createConnection({
    //主机地址
    host: '127.0.0.1',//字符集
    charset: 'utf8'
});

//注意通过util.promisify进行包装的函数,必须满足
//1、函数的最后一个参数是回调函数
//2、回调函数的参数为(err,result),前者是错误,后者是正常结果
//注意这里不要重新创建一个变量,不然会报错。
conn.query = util.promisify(conn.query);

(async function () {
    let result = await conn.query('select * from tb_user');
    console.log(result);
    let row = await conn.query('select * from tb_user where id = ?',[result[0].id]);
    console.log(row);
    conn.end();
})();

  

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


这篇文章主要介绍“基于nodejs的ssh2怎么实现自动化部署”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“基于nodejs...
本文小编为大家详细介绍“nodejs怎么实现目录不存在自动创建”,内容详细,步骤清晰,细节处理妥当,希望这篇“nodejs怎么实现目录不存在自动创建”文章能帮助大...
这篇“如何把nodejs数据传到前端”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这...
本文小编为大家详细介绍“nodejs如何实现定时删除文件”,内容详细,步骤清晰,细节处理妥当,希望这篇“nodejs如何实现定时删除文件”文章能帮助大家解决疑惑...
这篇文章主要讲解了“nodejs安装模块卡住不动怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来...
今天小编给大家分享一下如何检测nodejs有没有安装成功的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文...
本篇内容主要讲解“怎么安装Node.js的旧版本”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎...
这篇“node中的Express框架怎么安装使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家...
这篇文章主要介绍“nodejs如何实现搜索引擎”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“nodejs如何实现搜索引擎...
这篇文章主要介绍“nodejs中间层如何设置”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“nodejs中间层如何设置”文...
这篇文章主要介绍“nodejs多线程怎么实现”,在日常操作中,相信很多人在nodejs多线程怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法...
这篇文章主要讲解了“nodejs怎么分布式”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“nodejs怎么分布式”...
本篇内容介绍了“nodejs字符串怎么转换为数组”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情...
这篇文章主要介绍了nodejs如何运行在php服务器的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇nodejs如何运行在php服务器文章都...
本篇内容主要讲解“nodejs单线程如何处理事件”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“nodejs单线程如何...
这篇文章主要介绍“nodejs怎么安装ws模块”,在日常操作中,相信很多人在nodejs怎么安装ws模块问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法...
本篇内容介绍了“怎么打包nodejs代码”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!
本文小编为大家详细介绍“nodejs接收到的汉字乱码怎么解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“nodejs接收到的汉字乱码怎么解决”文章能帮助大家解...
这篇“nodejs怎么同步删除文件”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇...
今天小编给大家分享一下nodejs怎么设置淘宝镜像的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希