1

看看下面的查询。如何将“操作”列显示为文本。如果“Action”的结果是 LEQ 0,则显示文本“Crash”,如果“Action”是 GRT 0,则显示文本“Hold”?

SELECT col1 AS Action
FROM vdk
WHERE t_stamp Between "{StartTime}" AND "{EndTime}"
4

3 回答 3

2

重构上面的答案,因为我认为没有必要将查询添加到别名表。我认为这应该可以工作,另一个答案应该也可以工作,但它的查询更复杂一点,没有给定的原因。

SELECT (CASE WHEN col1 <= 0 THEN 'Crash' ELSE 'Hold' END) AS Action
FROM vdk
WHERE t_stamp Between "{StartTime}" AND "{EndTime}"
于 2018-08-22T22:56:35.703 回答
1

使用CASE WHEN ... ELSE ... END您的集合(查询)中选择:

SELECT *, (CASE WHEN Action <= 0 THEN 'Crash' ELSE 'Hold' END) as ActionText
FROM (
    SELECT col1 AS Action
    FROM vdk
    WHERE t_stamp Between "{StartTime}" AND "{EndTime}"
) q
于 2018-08-22T21:42:43.863 回答
0

这个应用程序类似于我的第一个问题,我认为它可能会帮助其他人。用户可以从表的下拉列表中选择一组选项以将值输入数据库。

使用 Ignition 的 Power Table 组件的扩展功能 configureEditor 和以下脚本。此脚本设置下拉列表。

if colName == 'Action':
   return {options': [(0, 'Null'), (1, 'HOLD'), (2, 'CRASH')]}

以及同一个 Power Table 的扩展函数 onCellEdited 脚本。此脚本将选择作为值输入到数据库中。

#onCellEdited Upadte Query
row = rowIndex
col = colIndex
colName = colName
value = newValue

ndx = self.data.getValueAt(row,0)
query = "UPDATE vdk SET %s = ? WHERE ndx = ?" % colName
system.db.runPrepUpdate(query,[value,ndx],'history')
system.db.refresh(self.data)
于 2019-08-29T01:17:17.407 回答