SQL下一行减去上一行的值插入另一表

如图为模拟数据,无自增长id,无标识列,在不更改表结构的情况下实现:收入列下一行减去上一行数据,差值插入另一个表。如:15.21-13.08 19.01.15.21 25.01-19.01 得出的值插入另一个表。
要求用SQL语句,自连接或者更简单的方法实现也行,最少要两种SQL语句实现该功能。 跪求大神指点(插入的表列可以自定义,语句有注释更好,跪求)

第1个回答  2017-08-30
SQL下一行减去上一行的值插入另一表
测试数据.
CREATE TABLE temp (
year INT,
salary INT
);

INSERT INTO temp VALUES(2000, 1000);
INSERT INTO temp VALUES(2001, 2000);
INSERT INTO temp VALUES(2002, 3000);
INSERT INTO temp VALUES(2003, 4000);本回答被网友采纳
第2个回答  2018-05-08
大概sql语句就这样了。没有执行,也不知道是不是你想要的。
SELECT 收入1-收入 AS 收入差
FROM
(
SELECT * FROM (SELECT * FROM (select Row_Number() over ( order by 时间 ) as rn1 , 收入 AS 收入1 from rn_ext_vir_instance_charge_history) AA) BB
INNER JOIN
(SELECT * FROM (SELECT * FROM (select Row_Number() over ( order by 时间 ) as rn , 收入 from rn_ext_vir_instance_charge_history) CC) DD) EE
ON BB.rn1=EE.rn+1
)FF
第3个回答  2015-08-07
悬赏太少,写出来后,注释你未必能明白。
告诉你思路吧,其实使用中间变量就可以做到的追问

40f分全部家当 都压上