select '字段' ,GasUserID,DataDate,value1 from 表名
where GasUserID='1010200100002'
ORDER BY GasUserID,DataDate,Convert(decimal(18,2),Value1) desc
实现目标 3,4,5行数据符合要求,字段为一样的数字
数据有什么问题吗?已经是正确的排序了、时间递增、相同时间的用量递减
以下sql仅供参考,未运行过
-- 创建存储过程之前需判断该存储过程是否已存在,若存在则删除
DROP PROCEDURE IF EXISTS shxc40;
-- 创建存储过程
CREATE PROCEDURE shxc40()
BEGIN
-- 定义变量
DECLARE s int DEFAULT 0;
DECLARE id_ bigint(20);
DECLARE valueOld decimal(2);
DECLARE valueNew decimal(2);
-- 定义游标,并将sql结果集赋值到游标中
DECLARE report CURSOR FOR select id,value1 from 表名
where GasUserID='1010200100002'
ORDER BY GasUserID,DataDate;
-- 声明当游标遍历完后将标志变量置成某个值
DECLARE CONTINUE HANDLER FOR NOT FOUND SET s=1;
-- 打开游标
open report;
-- 将游标中的值赋值给变量,注意:变量名不要和返回的列名同名,变量顺序要和sql结果列的顺序一致
fetch report into id_,valueOld;
-- 当s不等于1,也就是未遍历完时,会一直循环
while s<>1 do
fetch report into id_,valueNew;
IF valueNew< valueOld then
-- 执行业务逻辑
UPDATE 表名 set '字段' = '字段' where id= id_
end if;
-- 当s等于1时表明遍历以完成,退出循环
fetch report into id_,valueOld;
end while;
-- 关闭游标
close report;
END;
-- 执行存储过程
call shxc40()
求大佬解答