oracle行转列sql
时间: 2023-07-03 20:21:58 浏览: 99
Oracle中可以使用PIVOT操作将行转列,具体可以按照如下的语法进行操作:
```
SELECT *
FROM (
SELECT [列1], [列2], [列3]
FROM [表名]
)
PIVOT (
MAX([目标列])
FOR [要转换的列]
IN ([列1], [列2], [列3])
)
```
例如,假设我们有一个名为sales的表,其中包含了日期、销售额和销售人员的信息。我们可以使用如下的语句将销售人员作为列,日期作为行,将销售额进行转换:
```
SELECT *
FROM (
SELECT sales_date, sales_person, sales_amount
FROM sales
)
PIVOT (
SUM(sales_amount)
FOR sales_person
IN ('John', 'Jane', 'Mike')
)
```
这样就可以将sales表中的数据从行转换为列,方便进行数据分析和报表制作。
相关问题
oracle 行转列 sql写法示例
在Oracle中,可以使用pivot关键字将行转列。下面是一个示例:
SELECT *
FROM (
SELECT column1, column2, column3
FROM table_name
)
PIVOT (
MAX(column3)
FOR column2 IN ('value1', 'value2', 'value3')
);
其中,column1是要保留的列,column2是要转换的列,column3是要聚合的列。'value1', 'value2', 'value3'是column2列中要转换的值。MAX(column3)表示对column3列进行聚合操作,可以根据需要进行更改。
sql oracle 行转列 列转行
SQL Oracle中的行转列和列转行可以通过不同的方法来实现。在早期版本的Oracle中,可以使用函数如CONCAT、POSSTR和LOCATE来实现行转列和列转行。这些函数可以按照标点将多列转换为一行或者将多行转换为一列。
在较新的Oracle版本中,可以使用decode函数、PIVOT函数和case语句来实现行转列和列转行。使用decode函数可以实现行转列,适用于8i、9i、10g和以后版本。使用PIVOT函数可以实现行转列,适用于11g和以后版本。使用case语句也可以实现行转列和列转行。
以下是几个示例查询:
使用decode函数实现行转列:
SELECT NO, SUM(decode(monthh, '01', total)) "一月", SUM(decode(monthh, '02', total)) "二月", SUM(decode(monthh, '03', total)) "三月"
FROM FEE
GROUP BY NO
ORDER BY NO asc;
使用PIVOT函数实现行转列:
SELECT *
FROM FEE a
PIVOT ( sum(nvl(a.total,0)) FOR monthh IN ('01' as 一月,'02' as 二月,'03' as 三月))
ORDER BY NO asc;
使用case语句实现行转列和列转行:
SELECT NO, sum(case when Monthh='01' then TOTAL end) as 一月, sum(case when Monthh='02' then TOTAL end) as 二月, sum(case when Monthh='03' then TOTAL end) as 三月
FROM FEE
GROUP BY NO
ORDER BY NO asc;
阅读全文