温欣爸比

  • 主页
  • Alfred Workflow
  • 《Vim 练级手册》
  • 常用命令
  • 代码笔记
  • 合辑
  • 在线工具
所有文章 友链 关于我

温欣爸比

  • 主页
  • Alfred Workflow
  • 《Vim 练级手册》
  • 常用命令
  • 代码笔记
  • 合辑
  • 在线工具

Mysql 实现 Rank 排名查询

2017-12-24

Mysql 中没有像 Oracle 中那样的 Rank 函数来实现查询的排名排序,但是我们可以用一
些基础查询语句来实现同样的效果。

先创建一个表来作为例子

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
drop table if exists `post`;
create table `post`(
id int(11) not null AUTO_INCREMENT,
url VARCHAR(512) not null default '' COMMENT '地址',
pv int(11) not null default 0 COMMENT '访问量',
primary key(`id`)
) engine=InnoDB default charset=utf8mb4 COMMENT '博客';
INSERT INTO `post` (`url`, `pv`) VALUES
('/p/1', 22),
('/p/2', 21),
('/p/3', 50),
('/p/4', 5),
('/p/5', 15),
('/p/6', 23),
('/p/7', 45),
('/p/8', 35),
('/p/9', 20);

我们想要对 pv 字段进行倒序排名

1
select @rank := @rank +1 as rank, url, pv from `post` p, (select @rank := 0) r order by pv desc;

如果你按照我上边的语句执行,你会得到如下的结果

1
2
3
4
5
6
7
8
9
1    /p/3    50
2 /p/7 45
3 /p/8 35
4 /p/6 23
5 /p/1 22
6 /p/2 21
7 /p/9 20
8 /p/5 15
9 /p/4 5

有结果来看,我们已经得到了想要的结果,下面我们来看看怎么实现的。

首先简单说下 Mysql 中的变量,需要以 @ 开头,及 @rank,想要给变量赋值分两种。
SET 语句

1
2
set @name = 'wxnacy';
select @name;

SELECT 语句

1
select @name := 'wxnacy';

两者的区别在于 set 命令需要两条命令查询,select 命令中使用 := 赋值
而 @rank := @rank + 1 就是在查询语句中达到自增的目的,也就变相的实现了 rank 函数。

最近更新
Alfred Workflow 命令行帮助工具
最近热读
Go 判断数组中是否包含某个 item
Vim 高级功能 vimgrep 全局搜索文件
办理北京工作居住证的一些细节
Go 语法错误:Non-declaration statement outside function body
Mac 电脑查看字体文件位置
扫码关注公众号,或搜索公众号“温欣爸比” 及时获取我的最新文章
赏

谢谢你请我喝咖啡

支付宝
微信
  • mysql
MessagePack 实现序列化
关于美国税收
目录,不存在的…
© 2017 - 2022 温欣爸比 京ICP备15062634号 总访问量3736次 访客数3687人次 本文总阅读量2次
Hexo Theme Yilia by Litten
  • 所有文章
  • 友链
  • 关于我

tag:

  • python
  • flask
  • javascript
  • docker
  • 工具
  • openresty
  • 微信
  • java
  • hexo
  • 杂谈
  • vim
  • git
  • mysql
  • http
  • linux
  • mac
  • tmux
  • ssh
  • 算法
  • 开发
  • node
  • 杂文
  • jinja2
  • maven
  • spring
  • 北京
  • 生活
  • springboot
  • react
  • shell
  • graphql
  • iterm
  • expect
  • nginx
  • sqlalchemy
  • html
  • electron
  • vagrant
  • elastic
  • 宝贝
  • ansible
  • css
  • jquery
  • go
  • markdown
  • awk
  • redis
  • leetcode
  • zsh
  • 漫威
  • ssr
  • android
  • ffmpeg
  • chrome
  • vmware
  • youtube
  • windows
  • jupyter
  • excel
  • jq
  • Mac
  • Homebrew
  • mongo
  • py2
  • HomeBrew
  • movie
  • nodejs

    缺失模块。
    1、请确保node版本大于6.2
    2、在博客根目录(注意不是yilia根目录)执行以下命令:
    npm i hexo-generator-json-content --save

    3、在根目录_config.yml里添加配置:

      jsonContent:
        meta: false
        pages: false
        posts:
          title: true
          date: true
          path: true
          text: false
          raw: false
          content: false
          slug: false
          updated: false
          comments: false
          link: false
          permalink: false
          excerpt: false
          categories: false
          tags: true
    

  • Guru99
每天看书
每天背单词
每天一篇
写写代码
听听周杰伦
爱爱老婆