要对mysql进行操做,咱们须要安装一个mysql的库。php
1、安装mysql库node
npm install mysql --save
2、对mysql进行简单查询操做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();
2、对mysql进行增删改操做sql
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('链接成功'); }); //插入数据,query()方法能够对sql语句进行参数绑定,用?号做为占位符。 conn.query('insert into tb_user values(null, ?, ?)', ['xxx', 'xxx'], function (err, 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], function (err, data) { if (err) { throw err; } if (data && data.affectedRows) { console.log('修改数据成功'); } }); //删除数据 conn.query('delete from tb_user where id = ?', [5], function (err, data) { if (err) { throw err; } if (data && data.affectedRows) { console.log('删除数据成功'); } }); //关闭数据库链接 conn.end();
3、使用mysql链接池来优化对数据库的操做数据库
频繁的链接和断开mysql是比较消耗资源的,咱们能够建立一个链接池,复用链接池中的链接,提升效率。npm
const mysql = require('mysql'); //建立数据库链接池 let pool = mysql.createPool({ //链接数量,默认是10 connectionLimit: 20, //主机地址 host: '127.0.0.1', //用户名 user: 'root', //密码 password: '123456', //数据库 database: 'test', //端口 port: 3306, //字符集 charset: 'utf8' }); //pool.query()方法能够自动的帮咱们在链接池中获取可用链接 pool.query('select * from tb_user', function (err, data) { if (err) { throw err; } data.forEach(function (value) { console.log(value.id, value.user_name, value.addr); }); }); //固然咱们也能够手动获取可用链接 pool.getConnection(function (err, conn) { if (err) { throw err; } conn.query('select * from `order`', function (err, 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);
4、按流的方式进行查询数组
const mysql = require('mysql'); //建立数据库链接 let conn = mysql.createConnection({ //主机地址 host: '127.0.0.1', //用户名 user: 'root', //密码 password: '123456', //数据库 database: 'test', //端口 port: 3306, //字符集 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()方法返回一个可读流来获取数据promise
const mysql = require('mysql'); //建立数据库链接 let conn = mysql.createConnection({ //主机地址 host: '127.0.0.1', //用户名 user: 'root', //密码 password: '123456', //数据库 database: 'test', //端口 port: 3306, //字符集 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();
5、mysql的事务处理async
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.beginTransaction(function (err) { if (err) { throw err; } conn.query('update account set money = money - 50 where name = ?', ['A'], function (err, data) { if (err) { //若是有错误则回滚 return conn.rollback(function () { throw err; }); } conn.query('update account set money = money + 50 where name = ?', ['B'], function (err, 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(); }); }); }); });
6、解决mysql嵌套回调的问题函数
有些时候咱们的操做须要上一个操做的结果,这样会致使比较深的嵌套问题,为了解决可使用async和await来解决,而async和await又是基于promise的。
const mysql = require('mysql'); //建立数据库链接 let conn = mysql.createConnection({ //主机地址 host: '127.0.0.1', //用户名 user: 'root', //密码 password: '123456', //数据库 database: 'test', //端口 port: 3306, //字符集 charset: 'utf8' }); function query(conn, sql, params = []) { if (!conn) { return; } return new Promise(function (resolve, reject) { conn.query(sql, params, function (err, 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', //用户名 user: 'root', //密码 password: '123456', //数据库 database: 'test', //端口 port: 3306, //字符集 charset: 'utf8' }); //注意经过util.promisify进行包装的函数,必须知足 //一、函数的最后一个参数是回调函数 //二、回调函数的参数为(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(); })();