mysql数据库中如何实现同一列的数据相减(即下一行数据减去上一行数据)?

mysql数据库中如何实现同一列的数据相减(即下一行数据减去上一行数据)?,第1张

你需要知道在mysql数据库中是没有行,这一概念的。所以说,你让下一行减去上一行这个本身就是不成立的。处理的办法是把数据输出之后,用程序比如PHP。等等进行处理输出。单独用sql是无法实现的。

1、语句如下:

select A, B, A-B as C from 表1

2、计算列:

可以使用同一表中的其他列的表达式计算得来。表达式可以是非计算列的列名、常量、函数,也可以是用一个或多个运算符连接的上述元素的任意组合。表达式不能为子查询。

语句中的A-B就是计算列,as C的意思是给这个计算列起个列名叫C。

只要符合上述规则,你可以任意组合字段、运算符等,形成需要的计算列。

扩展资料:

计算列应用范围

计算列可用于选择列表、WHERE 子句、ORDER BY 子句或任何可使用正则表达式的其他位置,但下列情况除外:

用作 CHECK、FOREIGN KEY 或 NOT NULL 约束的计算列必须标记为 PERSISTED。如果计算列的值由具有确定性的表达式定义,并且索引列中允许使用计算结果的数据类型,则可将该列用作索引中的键列,或者用作 PRIMARY KEY 或 UNIQUE 约束的一部分。

例如,如果表中含有整数列 a 和 b,则可以对计算列 a + b 创建索引,但不能对计算列 a + DATEPART(dd, GETDATE()) 创建索引,因为在后续调用中,其值可能发生改变。

计算列不能作为 INSERT 或 UPDATE 语句的目标。

数据库引擎基于使用的表达式自动确定计算列的为 Null 性。即使只有非空列,大多数表达式的结果也“认为”可为空值,因为下溢或溢出生成的结果也可能为空。使用带 AllowsNull 属性的 COLUMNPROPERTY 函数可查明表中任何计算列的为 Null 性。通过指定 ISNULL (check_expression, constant) 可以将可为空值的表达式转换为不可为空值的表达式,其中, constant 是可替换所有空结果的非空值.

参考资料:

百度百科.计算列

--这样是显示的结果是差值总的秒数

select sum(unix_timestamp(B)-unix_timestamp(A)) as 秒数

from tb

--这样是显示成 xxx:xx:xx 的形式

select sec_to_time(sum(unix_timestamp(B)-unix_timestamp(A))) as ti

from tb

--


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/8458101.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-16
下一篇 2023-04-16

发表评论

登录后才能评论

评论列表(0条)

保存