需求:请删除 exam_record 表中未完成作答或作答时间小于5分钟整的记录中,开始作答时间最早的3条记录。 我写的sql,麻烦指出错误并且纠正: SELECT ROWNUM,tt.* FROM EXAM_RECORD tt WHERE (SUBMIT_TIME IS NULL OR ((TO_DATE(TO_CHAR(SUBMIT_TIME, 'yyyy-mm-dd hh24-mi-ss'), 'yyyy-mm-dd hh24-mi-ss') - TO_DATE(TO_CHAR(START_TIME, 'yyyy-mm-dd hh24-mi-ss'), 'yyyy-mm-dd hh24-mi-ss'))) * 24 * 60 < 5) AND ROWNUM IN (SELECT XUHAO FROM (SELECT ROWNUM XUHAO, E.* FROM EXAM_RECORD E WHERE (SUBMIT_TIME IS NULL OR ((TO_DATE(TO_CHAR(SUBMIT_TIME, 'yyyy-mm-dd hh24-mi-ss'), 'yyyy-mm-dd hh24-mi-ss') - TO_DATE(TO_CHAR(START_TIME, 'yyyy-mm-dd hh24-mi-ss'), 'yyyy-mm-dd hh24-mi-ss'))) * 24 * 60 < 5) ORDER BY START_TIME) A WHERE A.XUHAO <= 3)
时间: 2024-02-14 16:36:14 浏览: 164
sql删除表中的记录的方法
您的 SQL 语句有一些错误,具体如下:
1. ROWNUM 不能直接被 SELECT,需要先进行子查询,再在子查询中使用 ROWNUM。
2. TO_DATE 函数的格式字符串中,分钟应该使用大写的 MI,而不是小写的 mi。
3. 在子查询中,需要先按照 START_TIME 进行排序,再取前三条记录。因为 ROWNUM 是在排序之后才会分配的。
下面是修改后的 SQL 语句:
SELECT *
FROM (
SELECT ROWNUM AS RN, E.*
FROM (
SELECT *
FROM EXAM_RECORD
WHERE SUBMIT_TIME IS NULL
OR (SUBMIT_TIME - START_TIME) * 24 * 60 < 5
ORDER BY START_TIME
) E
)
WHERE RN <= 3;
这条 SQL 语句会先筛选出未完成作答或作答时间小于 5 分钟的记录,然后按照开始作答时间进行排序,最后取前三条记录。注意,这里使用了子查询和 ROWNUM 来实现取前三条记录的功能。
阅读全文