看看下面的查询。如何将“操作”列显示为文本。如果“Action”的结果是 LEQ 0,则显示文本“Crash”,如果“Action”是 GRT 0,则显示文本“Hold”?
SELECT col1 AS Action
FROM vdk
WHERE t_stamp Between "{StartTime}" AND "{EndTime}"
重构上面的答案,因为我认为没有必要将查询添加到别名表。我认为这应该可以工作,另一个答案应该也可以工作,但它的查询更复杂一点,没有给定的原因。
SELECT (CASE WHEN col1 <= 0 THEN 'Crash' ELSE 'Hold' END) AS Action
FROM vdk
WHERE t_stamp Between "{StartTime}" AND "{EndTime}"
使用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
这个应用程序类似于我的第一个问题,我认为它可能会帮助其他人。用户可以从表的下拉列表中选择一组选项以将值输入数据库。
使用 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)