指定一个ID找到上下的范围

倒是不复杂
需求:
指定一个ID找到上下的范围

实现思路:
给定一个ID,比如272944
如果表中的ID大于这个值,则自定义变量自增加一,
如果表中的ID小于这个值,则用这个值减去表中ID,
如果表中的ID等于这个值,则为0

  1.     SELECT   
  2.         a.ZpID,  
  3.             WHEN a.zpid - 272944 > 0 THEN @a:=@a + 1  
  4.                 WHEN a.zpid - 272944 < 0 THEN a.zpid - 272944  
  5.                 ELSE 0  
  6.             END AS rn  
  7.     FROM  
  8.         zp_audio_video a, (SELECT @a:=0) vars  
  9.     WHERE  
  10.         a.State = 1  
  11.             AND a.Labels LIKE '三周年站庆歌曲类%'  
  12.     ORDER BY a.Zpid  

结果:
指定一个ID找到上下的范围

最后过滤找到结果:
  1. SELECT   
  2.     *  
  3. FROM  
  4.     (  
  5.         SELECT   
  6.             a.ZpID,  
  7.                 WHEN a.zpid - 272944 > 0 THEN @a:=@a + 1  
  8.                     WHEN a.zpid - 272944 < 0 THEN a.zpid - 272944  
  9.                     ELSE 0  
  10.                 END AS rn  
  11.         FROM  
  12.             zp_audio_video a, (SELECT @a:=0) vars  
  13.         WHERE  
  14.             a.State = 1  
  15.                 AND a.Labels LIKE '三周年站庆歌曲类%'  
  16.         ORDER BY a.Zpid  
  17.     ) a  
  18. WHERE  
  19.     rn <= 5 AND rn != 0  
  20. ORDER BY rn DESC  
  21. LIMIT 10;  

指定一个ID找到上下的范围


文章名称:指定一个ID找到上下的范围
浏览地址:https://www.cdcxhl.com/article22/posdcc.html

成都网站建设公司_创新互联,为您提供App设计自适应网站搜索引擎优化用户体验服务器托管电子商务

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

外贸网站建设