色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

nodeJS與MySQL實現(xiàn)分頁數(shù)據(jù)以及倒序數(shù)據(jù)

瀏覽:4日期:2023-10-14 15:55:52

大家在做項目時肯定會遇到列表類的數(shù)據(jù),如果在前臺一下子展示,速度肯定很慢,那么我們可以分頁展示,比如說100條數(shù)據(jù),每10條一頁,在需要的時候加載一頁,這樣速度肯定會變快了。那么這里我給大家介紹如何在nodejs環(huán)境中用mysql實現(xiàn)分頁。

前面一些必要的配置我先不詳細說了,這里主要說的是地址池的配置

// 數(shù)據(jù)庫信息var connection = mysql.createConnection({ host : ’localhost’, port:3306, user : ’root’, password : ’’, database : ’url’, multipleStatements: true //這里一定要加上這個。先別管什么用,一定要加上。});

因為我使用的是koa框架,所以用了async 、await 。這里不做理會,下面的代碼才重要。

// 獲取urlrouter.post(’/csdnurl’, async (ctx, next) => { var start = (ctx.request.body.page - 1) * 10; var sql = ’SELECT COUNT(*) FROM csdnurl ORDER BY id DESC; SELECT * FROM csdnurl ORDER BY id DESC limit ’ + start + ’,10’; let results = await query2(sql); ctx.body = results});const query2 = function (sql) { return new Promise((resolve, reject) => { connection.query(sql, function (error, results) { if (error) {reject(error); } else { var allCount = results[0][0][’COUNT(*)’]; var allPage = parseInt(allCount) / 10; var pageStr = allPage.toString(); if (pageStr.indexOf(’.’) > 0) { allPage = parseInt(pageStr.split(’.’)[0]) + 1; console.log(allPage) } var List = results[1];resolve(List) } }); })

1、ctx.request.body.page這里是前臺傳來的頁數(shù)。

2、 你可以看到sql語句有兩條,哈哈,這里是關(guān)鍵了,在地址池配置multipleStatements: true就是這個原因,如果你不加,就會報錯。

3、ORDER BY id DESC 這是倒序的意思(根據(jù)id倒序)。

4、 然后我使用await 異步操作封裝了一個函數(shù),是為了能夠取到results值。當然你使用了express就不用考慮這一點,為啥會這樣呢?如下:

關(guān)于使用 koa路由與mysql模塊, ctx.body獲取不到值的問題

var Koa = require(’koa’);var Router = require(’koa-router’ );var bodyParser = require(’koa-bodyparser’);var mysql = require(’mysql’);var app = new Koa();var router = new Router();app.use(bodyParser());var connection = mysql.createConnection({ host : ’localhost’, port:3306, user : ’root’, password : ’xxx’, database : ’url’});connection.connect();//第一類封裝 ,一般用于不傳遞多個參數(shù)const query = function (sql) { return new Promise((resolve, reject) => { connection.query(sql, function (error, results) { if(error){reject(error); }else{resolve(results) } }); })}//第二類封裝 ,一般用于傳遞多個參數(shù)const query1 = function (userStr,name,passwd,token1) { return new Promise((resolve, reject) => { connection.query(userStr, function (error, result) { if(error){reject(error); }else{if (result.length > 0) { json[’message’] = ’用戶已經(jīng)存在’; json[’resultCode’]= 1;} else { json[’message’] = ’注冊成功’; json[’token’] = token1; json[’resultCode’] = 200; var insertStr = `insert into login (username, password,token) values ('${name}', '${passwd}','${token1}')`; console.log(insertStr) connection.query(insertStr, function (err, res) { if (err) throw err; })}resolve(json) } }); })}// 使用第一類封裝router.get( ’/csdnurl’, async(ctx, next) => { var sql = 'select * from csdnurl'; let results = await query(sql); ctx.body=results});// 使用第一類封裝router.post(’/login’, async (ctx, next) => { var name = ctx.request.body.username; var passwd = ctx.request.body.password; var userStr = `select username,password,token from login where username='${name}' and password='${passwd}'`; let results = await query(userStr); ctx.body = results});// 使用第二類封裝router.post(’/register’, async (ctx, next) => { var name = ctx.request.body.username; var passwd = ctx.request.body.password; var token1 = jwt.sign({ username: name }, secretkey, { expiresIn: 60 * 8 }); var userStr = `select * from login where username='${name}'`; let results = await query1(userStr,name,passwd,token1); ctx.body = json});

5、allPage是所有的頁數(shù),因為可能遇到小數(shù)的情況所以向下取整加一。

6、resolve(List) 返回給前臺數(shù)據(jù)

到此這篇關(guān)于nodeJS與MySQL實現(xiàn)分頁數(shù)據(jù)以及倒序數(shù)據(jù)的文章就介紹到這了,更多相關(guān)nodeJS MySQL分頁及倒序內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

相關(guān)文章:
主站蜘蛛池模板: 日韩免费一区二区三区 | 欧美日韩在线看 | 日本不卡免费高清一级视频 | 亚州视频一区二区 | 在线播放国产一区二区三区 | 一区二区三区在线免费观看视频 | 亚洲另类自拍 | 欧美综合视频在线 | 又粗又爽又色男女乱淫播放男女 | 99久久香蕉国产线看观香 | 2022国产精品网站在线播放 | a级片在线免费观看 | 日韩在线视屏 | 91精品啪在线看国产网站 | 亚洲黄色三级视频 | 91精品乱码一区二区三区 | 一本色道久久88亚洲精品综合 | 久久久国产免费影院 | 亚洲国产一区二区三区四区五区 | 日本在线 | 中文 | 中文字幕在线看视频一区二区三区 | 国产成人精品三级91在线影院 | 免费的特黄特色大片在线观看 | 美女张开腿让男人捅爽 | 高清国产美女一级a毛片 | 国产亚洲女在线精品 | 久久毛片免费 | 国产在线精品一区二区高清不卡 | 成人a级 | 永久免费91桃色福利 | 日本精品视频一视频高清 | 国产女女视屏免费 | 在线免费观看日本视频 | 国产日b视频 | 黄网视频在线观看 | 一级做a级爰片性色毛片视频 | 国内自产拍自a免费毛片 | 精品久久久日韩精品成人 | 国产在线爱做人成小视频 | 亚洲免费人成在线视频观看 | 欧美午夜免费一级毛片 |