oracle一个表或者视图中有 a,b字段,如下面补充,求sql语句,谢谢
比如
a b
北京 故宫
北京 颐和园
北京 长城
上海 外滩
上海 浦东
上海 故宫
......
1.先显示: 北京,故宫、颐和园、长城
上海,外滩、浦东、故宫
create table test_tab(province varchar2(20),landscapes varchar2(50));
insert into test_tab values('北京','故宫');
insert into test_tab values('北京','颐和园');
insert into test_tab values('北京','长城');
insert into test_tab values('上海','外滩');
insert into test_tab values('上海','浦东');
insert into test_tab values('上海','世博园');
insert into test_tab values('四川','蜀南竹海');
select * from test_tab;
--------------------------------------
PROVINCE LANDSCAPES
1 北京 故宫
2 北京 颐和园
3 北京 长城
4 上海 外滩
5 上海 浦东
6 上海 世博园
7 四川 蜀南竹海
--------------------------------------
SELECT province, SUBSTR(MAX(SYS_CONNECT_BY_PATH(landscapes, ',')), 2) NAME
FROM (SELECT province,
landscapes,
rn,
LEAD(rn) OVER(PARTITION BY province ORDER BY rn) rn1
FROM (SELECT province, landscapes, ROW_NUMBER() OVER(ORDER BY landscapes) rn
FROM test_tab))
START WITH rn1 IS NULL
CONNECT BY rn1 = PRIOR rn
GROUP BY province;
----------------------------------------
PROVINCE NAME
1 北京 颐和园,故宫,长城
2 上海 外滩,世博园,浦东
3 四川 蜀南竹海
Oracle函数sys_connect_by_path 详解:
语法:
Oracle函数:sys_connect_by_path 主要用于树查询(层次查询) 以及 多列转行。其语法一般为:
select ... sys_connect_by_path(column_name,'connect_symbol') from table
start with ... connect by ... prior
理解:
对于数据库来说,根节点并不一定是在数据库中设计的顶级节点,而是start with开始的地方。sys_connect_by_path函数就是从start with开始的地方开始遍历,并记下其遍历到的节点,start with开始的地方被视为根节点,将遍历到的路径根据函数中的分隔符,组成一个新的字符串。sys_connect_by_path函数用connect by来寻找下一条记录,直到迭代找不到相应记录为止。概念与递归类似,connect by指定递归(连接)条件,如果条件不满足则递归结束。
结束语:
其实可以用一条语句实现,不过要在10G以上的版本才可以,SQL如下:
select t.place,wm_concat(t.jing)
from test_tab t
group by t.place;
- 大小: 2.8 KB
分享到:
相关推荐
sql列转行以及行转列的通用存储过程!mssqlserver版本!
sql 行转列 与列转行,oracle ,msssql等,详细数据库操作方法,各种例子,欢迎大家学习。、~
DB2 SQL 通过函数(CONCAT/POSSTR/LOCATE)实现行转列,列转行 可以按照标点把多列转换为一行,多行转换为一列
Sql语句实现表的行列转换,行转列,列转行
oracle的列转行问题 oracle的列转行问题
oracle developer 列转行 in的入参转换
SQL行专列列转行的存储过程 很实用的 SQL行专列列转行的存储过程 很实用的
mysql行转列(将同一列下的不同内容的几行数据,转换成几列显示)、列转行、行列汇总、合并显示
SQL Server 列转行代码,供大伙参考
sql2005列转行存储过程代码,此代码分静态列表列转行和动态列表列转行,本代码在sql2005上测试通过。
精典的SQL语句。行转列,列转行的语句精典的SQL语句。行转列,列转行的语句
SqlServer列转行的另一种方式!
可以把一列转成一行…… 分隔符默认为英文逗号,也可以转成INSERT 中VALUES()后面的单引号加逗号的形式。 以前用T-SQL时,总是把一列复制到EXCEL中,转置,然后复制到记本事中,把一空格替换成逗号……,这个工具...
sqlserver使用UNPIVOT函数列转行
主要介绍了Python pandas 列转行操作详解(类似hive中explode方法),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
SQL列转行的方法 介绍的是两种列转行的方法。简单易懂...
Mysql 行转列,列转行 SQL语句和示例表结构SQL Mysql 行转列,列转行 SQL语句和示例表结构SQL
EXCEL横转竖(列转行)宏工具。可以用以小区排列转换等等。
oracle列转行的方法,有些时候页面显示要通过后台的列转行去实现,我们可以直接从sql中解决后台很复杂的问题
oracle中实现列转行实例,有表的创建,数据的插入,查询的sql