日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

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

發(fā)布時間:2025/7/14 数据库 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 node.js中对 mysql 进行增删改查等操作和async,await处理 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

要對mysql進(jìn)行操作,我們需要安裝一個mysql的庫。

一、安裝mysql庫

npm install mysql --save

  

二、對mysql進(jìn)行簡單查詢操作

const mysql = require('mysql');//創(chuàng)建數(shù)據(jù)庫連接 let conn = mysql.createConnection({//主機(jī)地址host: '127.0.0.1',//用戶名user: 'root',//密碼password: '123456',//數(shù)據(jù)庫database: 'test',//端口port: 3306,//字符集charset: 'utf8' });//連接數(shù)據(jù)庫 conn.connect(function (err) {if (err) {throw err;}console.log('連接成功'); });//查詢數(shù)據(jù)庫 conn.query('select * from tb_user', function (err, data, field) {if (err) {throw err;}//data表示結(jié)果集數(shù)據(jù),是一個數(shù)組console.log(data);data.forEach(function (value) {console.log(value.id, value.user_name, value.addr);});//表字段的詳細(xì)信息console.log(field); });//關(guān)閉數(shù)據(jù)庫連接 conn.end();

  

二、對mysql進(jìn)行增刪改操作

const mysql = require('mysql');//創(chuàng)建數(shù)據(jù)庫連接 let conn = mysql.createConnection({//主機(jī)地址host: '127.0.0.1',//用戶名user: 'root',//密碼password: '123456',//數(shù)據(jù)庫database: 'test',//端口port: 3306,//字符集charset: 'utf8' });//連接數(shù)據(jù)庫 conn.connect(function (err) {if (err) {throw err;}console.log('連接成功'); });//插入數(shù)據(jù),query()方法可以對sql語句進(jìn)行參數(shù)綁定,用?號作為占位符。 conn.query('insert into tb_user values(null, ?, ?)', ['xxx', 'xxx'], function (err, data) {if (err) {throw err;}if (data && data.affectedRows) {console.log('插入數(shù)據(jù)成功,id為', data.insertId);} });//修改數(shù)據(jù) 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('修改數(shù)據(jù)成功');} });//刪除數(shù)據(jù) conn.query('delete from tb_user where id = ?', [5], function (err, data) {if (err) {throw err;}if (data && data.affectedRows) {console.log('刪除數(shù)據(jù)成功');} });//關(guān)閉數(shù)據(jù)庫連接 conn.end();

  

三、使用mysql連接池來優(yōu)化對數(shù)據(jù)庫的操作

頻繁的連接和斷開mysql是比較消耗資源的,我們可以創(chuàng)建一個連接池,復(fù)用連接池中的連接,提高效率。

const mysql = require('mysql');//創(chuàng)建數(shù)據(jù)庫連接池 let pool = mysql.createPool({//連接數(shù)量,默認(rèn)是10connectionLimit: 20,//主機(jī)地址host: '127.0.0.1',//用戶名user: 'root',//密碼password: '123456',//數(shù)據(jù)庫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);}); });//當(dāng)然我們也可以手動獲取可用連接 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();}); });//從連接池中獲取連接時,將觸發(fā)該事件 pool.on('acquire', function (conn) {console.log('獲取連接', conn.threadId); });//在連接池中建立新連接時,將觸發(fā)該事件 pool.on('connection', function (conn) {console.log('建立新連接', conn.threadId); });//等待可用連接時,將觸發(fā)該事件 pool.on('enqueue', function () {console.log('等待可用連接'); });//當(dāng)連接釋放回池中時,觸發(fā)該事件 pool.on('release', function (conn) {console.log('連接被釋放回池中', conn.threadId); });//結(jié)束池中所有的連接,不然node.js的事件循環(huán)會一直保持 setTimeout(function () {pool.end(function (err) {console.log('關(guān)閉連接池');console.log(err);}); }, 3000);

  

四、按流的方式進(jìn)行查詢

const mysql = require('mysql');//創(chuàng)建數(shù)據(jù)庫連接 let conn = mysql.createConnection({//主機(jī)地址host: '127.0.0.1',//用戶名user: 'root',//密碼password: '123456',//數(shù)據(jù)庫database: 'test',//端口port: 3306,//字符集charset: 'utf8' });let query = conn.query('select * from tb_user'); //Query類繼承自Sequence,而Sequence繼承自EventEmitter //所以Query類的實(shí)例是可以監(jiān)聽事件//發(fā)生錯誤時 query.on('error', function (err) {console.log(err); });//獲取查詢字段信息 query.on('fields', function (fields) {console.log(fields); });//獲取查詢結(jié)果 query.on('result', function (result) {//暫停獲取結(jié)果conn.pause();//跟流的pause()和resume()很類似,控制獲取數(shù)據(jù)的頻率。setTimeout(function () {console.log(result);//恢復(fù)獲取結(jié)果conn.resume();}, 1000); });//查詢結(jié)束 query.on('end', function () {console.log('查詢結(jié)束'); });conn.end();

通過query.stream()方法返回一個可讀流來獲取數(shù)據(jù)

const mysql = require('mysql');//創(chuàng)建數(shù)據(jù)庫連接 let conn = mysql.createConnection({//主機(jī)地址host: '127.0.0.1',//用戶名user: 'root',//密碼password: '123456',//數(shù)據(jù)庫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('查詢結(jié)束');console.log(result); });conn.end();

  

五、mysql的事務(wù)處理

const mysql = require('mysql');//創(chuàng)建數(shù)據(jù)庫連接 let conn = mysql.createConnection({//主機(jī)地址host: '127.0.0.1',//用戶名user: 'root',//密碼password: '123456',//數(shù)據(jù)庫database: 'test',//端口port: 3306,//字符集charset: 'utf8' });//連接數(shù)據(jù)庫 conn.connect(function (err) {if (err) {throw err;}console.log('連接成功'); });//開啟一個事務(wù) 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;});}//提交事務(wù)conn.commit(function (err) {if (err) {//如果有錯誤則回滾return conn.rollback(function () {throw err;});}console.log('處理成功');conn.end();});});}); });

  

六、解決mysql嵌套回調(diào)的問題

有些時候我們的操作需要上一個操作的結(jié)果,這樣會導(dǎo)致比較深的嵌套問題,為了解決可以使用async和await來解決,而async和await又是基于promise的。

const mysql = require('mysql');//創(chuàng)建數(shù)據(jù)庫連接 let conn = mysql.createConnection({//主機(jī)地址host: '127.0.0.1',//用戶名user: 'root',//密碼password: '123456',//數(shù)據(jù)庫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(); })();

當(dāng)然我們還可以使用 util.promiseify() 進(jìn)行包裝。

const mysql = require('mysql'); const util = require('util');//創(chuàng)建數(shù)據(jù)庫連接 let conn = mysql.createConnection({//主機(jī)地址host: '127.0.0.1',//用戶名user: 'root',//密碼password: '123456',//數(shù)據(jù)庫database: 'test',//端口port: 3306,//字符集charset: 'utf8' });//注意通過util.promisify進(jìn)行包裝的函數(shù),必須滿足 //1、函數(shù)的最后一個參數(shù)是回調(diào)函數(shù) //2、回調(diào)函數(shù)的參數(shù)為(err, result),前者是錯誤,后者是正常結(jié)果 //注意這里不要重新創(chuàng)建一個變量,不然會報錯。 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(); })();

  

轉(zhuǎn)載于:https://www.cnblogs.com/jkko123/p/10299227.html

總結(jié)

以上是生活随笔為你收集整理的node.js中对 mysql 进行增删改查等操作和async,await处理的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。