问题1:我有一个具有以下结构和数据的表:
app_id transaction_id mobile_no node_id customer_attribute entered_value
100 111 9999999999 1 Q1 2
100 111 9999999999 2 Q2 1
100 111 9999999999 3 Q3 4
100 111 9999999999 4 Q4 3
100 111 9999999999 5 Q5 2
100 222 8888888888 4 Q4 1
100 222 8888888888 3 Q3 2
100 222 8888888888 2 Q2 1
100 222 8888888888 1 Q1 3
100 222 8888888888 5 Q5 4
我想以以下格式显示这些记录:
app_id | transaction_id | mobile | Q1 | Q2 | Q3 | Q4 | Q5 |
100 | 111 | 9999999999 | 2 | 1 | 4 | 3 | 2 |
100 | 222 | 8888888888 | 3 | 1 | 2 | 1 | 4 |
我知道我需要使用交叉表/数据透视查询来获得此显示。为此,我基于对它的有限知识对其进行了尝试。
任何人都可以帮助我对查询进行适当的更改以获取单行而不是如上所述的多行记录。
问题2:还有一种方法可以获取特定字段的值作为列的名称。正如你可以在上面看到我有user_input1,user_input2,...作为标题。取而代之的是,我想将值customer_attribute作为列的标题。
为此,我检查NAME_CONST(name,value)如下:
SELECT app_id, transaction_id, mobile_no,
NAME_CONST(customer_attribute, (CASE node_id WHEN 1 THEN entered_value ELSE '' END))
FROM trn_user_log
但它给出了一个错误
Error Code : 1210 Incorrect arguments to NAME_CONST
需要帮助。
哔哔one
慕虎7371278
相关分类