sql-server - 使用 SQL 查询计算 MTBF
问题描述
我正在尝试计算故障开始与下一个(同一列)开始之间的预期平均时间[MTBF]。
我已经在这里找到了一个类似的问题,但它对我没有帮助。
我必须计算每行(其他列)的失败列((n + 1) - n)中的日期之间的差异,将其转换为小时并将其除以间隔数以计算平均时间。
这是我的桌子:
| Failure | Start_Repair | End_Of_Repair | Line | Piece |
|----------------------|----------------------|----------------------|-------|--------|
| 2019-06-26 06:30:00 | 2019-06-26 10:40:00 | 2019-06-27 12:00:00 | A | tube |
| 2019-06-28 00:10:00 | 2019-06-28 02:40:00 | 2019-06-29 01:12:00 | A | washer |
| 2019-06-30 10:10:00 | 2019-06-30 02:40:00 | 2019-07-01 00:37:00 | B | bolt |
| 2019-07-02 12:01:00 | 2019-07-02 14:24:00 | 2019-07-05 00:35:00 | B | engine |
所以我必须在失败列上做出区别,第二个减去第一,第三个减去第二等等。全部除以计算的间隔(这是我从第 2 行第 1 行开始的第 1 行数)。
这是我写的sql代码,不行。。。
SELECT ROW_NUMBER() over (ORDER BY t1.Line, t1.Failure ASC) AS 'Row',
(DATEDIFF(HOUR, T1.failure, T2.failure))/'Row' AS '[MTBF]'
From Test_Failure as t1, Test_Failure as t2
where t1.Failure < t2.Failure
错误: 将 varchar 值“Row”转换为数据类型 int 时转换失败。
结果应该回来:
A = (41.6 + 198.96)/2 = 120 小时
B = (49.85 + 116.35)/2 = 83,1h
解决方案
将 varchar 值 'Row' 转换为数据类型 int 时转换失败。
您收到此错误是因为您在第一列别名周围加上了单引号,然后尝试在计算第二列时使用它。你不能那样做。
这一行:
(DATEDIFF(HOUR, T1.failure, T2.failure))/'Row' AS '[MTBF]'
正在尝试将 DATEDIFF 结果(整数)除以单词“Row”(字符串)。你不能用一个词来除一个数字。
对于它的价值,即使您没有使用单引号,您仍然不能在另一列的计算中使用列的别名。
推荐阅读
- sql-server - 在 SQL Server 中运行 SELECT 时缺少行
- asp.net-core - 使用控制台应用在 Gitlab 上持续集成
- python - 计算 N 个样本和聚类质心之间的平方欧几里得距离的最有效方法是什么?
- javascript - 在 POST 上使用 JQuery 创建双下拉 SelectList 时返回 0。ASP.Net CORE 2.1
- java - Java Scanner 返回 null 但已过滤掉
- matlab - 使用 Matlab 查找函数使用其坐标获取顶点的索引
- javascript - 尝试设置随机重定向主页?
- selenium - 有没有办法改变 selenium/node-chrome 图像 chromedriver.exe 版本?
- python - 在 html 中搜索颜色标签 (Python 3)
- vb.net - 检查函数调用中哪个数字更大 - vb.net