查询文章的上下篇Sql语句
直接开入正题
文章内容页一般都会有上一篇和下一篇的功能;
那么查询上下篇的sql语句应该怎么写呢;
示例数据表:zmd_article
自增主键:id
当前文章id:10
肯定有人说,这简单啊id+1和id-1不就OK了;
sql无非如下:
1 SELECT * FROM zmd_article WHERE id=10-1; #上一篇 2 SELECT * FROM zmd_article WHERE id=10+1; #下一篇
写出这2句sql后;
大部分人稍加思索就会发现不妥;
如果中间删除了几篇;
那取到的值就成空了?
这时有人在一旁大喊;
可以用for循环啊;
再来个if直到不为空为止;
不经脑子的随便一想;
貌似行得通;
但是作为严谨的程序猿;
认真思考这个不算方法的方法时候立马发现2个严重的问题;
-
我只是想取上一篇文章;结果来了个for查询了NNNN次,严重浪费资源;
-
假设现在一共10篇文章,第11篇就为空了,如果用for就会无限循环下去一直为空;
如此来说;
果断是不能这样写了;
这时又有人在一旁大喊;
用limit不就可以了;
正解;
1 SELECT * FROM zmd_article WHERE id<10 LIMIT 1; #上一篇 2 SELECT * FROM zmd_article WHERE id>10 LIMIT 1; #下一篇
这就完了吗?
NO;
如果用这sql取;
下一篇没问题了;
但是上一篇会一直是第一篇文章!
这时来个倒序即可;
1 SELECT * FROM zmd_article WHERE id<10 ORDER BY id DESC LIMIT 1; #上一篇
感谢大家阅读到这里~~~
作者:子钦加油
出处:https://www.cnblogs.com/zmdComeOn/
个性签名:努力生活,努力走路
阿里云拼团:https://www.aliyun.com/1111/home?userCode=f4ee1llo1核2G1M,86一年,229三年;2核4G5M,799三年;2核8G5M,1399三年
腾讯云三月采购计划特价:https://cloud.tencent.com/act/cps/redirect?redirect=1073&cps_key=15d0b1673287c43fe946626d9f4e2eee&from=console1核2G1M,88一年;1核2G1M,268三年;2核4G5M,998一年;4核8G5M,2888元三年
出处:https://www.cnblogs.com/zmdComeOn/
个性签名:努力生活,努力走路
阿里云拼团:https://www.aliyun.com/1111/home?userCode=f4ee1llo1核2G1M,86一年,229三年;2核4G5M,799三年;2核8G5M,1399三年
腾讯云三月采购计划特价:https://cloud.tencent.com/act/cps/redirect?redirect=1073&cps_key=15d0b1673287c43fe946626d9f4e2eee&from=console1核2G1M,88一年;1核2G1M,268三年;2核4G5M,998一年;4核8G5M,2888元三年