mysql - SQL选择上一条记录所在

标签 mysql select join

所以我试图通过一个表来查询,称它为学生 如果 Student 中的“status”列为“active”,则从上一条记录中选择“firstName”和“lastName”列。每条记录都有一个主键。 也就是说,如果记录的“status”栏是=active,那么,我要选择上一条记录。 该表已经填充了类似的数据

id  firstname   lastname    status          email
9   Joe         Peters      inactive        fp@gmail.com
10  kim         Rol         active          rt@yh.com
11  Lance       Ree         inactive        lll&hh.com
12  diana       Jones       active          sams@yahoo.com

对于此数据,查询应返回 Joe peters 和 lance ree 我怎样才能做到这一点? 谢谢

最佳答案

如果您只想从学生活跃的记录中选择姓名,查询很简单

SELECT id, firstname, lastname
FROM students
WHERE status = "active"

我假设您所说的上一行您刚刚确定的那一行是活跃学生。该查询将检查您的表中的活跃学生并检索他们的姓名。因为名称很少是唯一的,所以我包含了 ID 列。 我还建议将状态列设置为 0 或 1 整数。

如果你真的想选择上一行,你可以使用

SELECT sj.id, sj.firstname, sj.lastname
FROM students AS s
LEFT JOIN students AS sj ON (sj.id = s.id - 1)
WHERE s.status = "active"

关键在于确定您拥有的行与要选择的行之间的关系。在这种情况下,您要选择 ID 比当前行小 1 的行。由于此约束非常严格,因此以这种方式选择行不是一个好主意。您可能想要重新设计您的数据库。

关于mysql - SQL选择上一条记录所在,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6706347/

相关文章:

MySQL CREATE USER 带有变量?

sql-server - SUM() 比 SQL 中的 SELECT() 花费的时间更少。怎么运行的?

mysql - 将 2 个 SELECT 语句合并到一个结果表中

mysql - 创建 View ?

mysql - 连接事务表创建事务语句

java - 使用内部联接获取一个月的所有周数据

mysql - 无法创建包含联合的 View

mysql - 如何撤回哪些学生成绩全为 4?

php - 购物车总数量仅在更新后读取购物车中的最后一个数字

mysql - MYSQL多表匹配结果