Oracle不同行的某列字符串相加,去除重复值
有如下表Test
City People Make
广州 1 A
广州 2 B
广州 3 C
上海 4 A
上海 5 E
广州 6 A
上海 7 E
实现如下效果
City People Make
上海 16 AE
广州 12 ABC
在公司论坛看到有人对这个要求的实现,觉得有点复杂。自己研究了下,重新写了下sql如下:
9I(没有环境测试,但是函数在9I中好像都是已经有了的):
WITH TEST AS (SELECT CITY,MAKE,SUM(PEOPLE) PEOPLE from Test GROUP BY CITY,MAKE ORDER BY CITY,MAKE)
SELECT CITY,SUM(PEOPLE),(select REVERSE(ltrim(max(sys_connect_by_path(MAKE,',')),',')) MAKE
from
(
SELECT MAKE,CITY,ROWNUM numberid from TEST
) T1 WHERE T1.CITY = T2.CITY
start with T.CITY = T2.CITY connect by prior numberid = numberid+1
) MAKE from TEST T2 GROUP BY CITY
10G:
WITH TEST AS (SELECT CITY,MAKE,SUM(PEOPLE) PEOPLE from Test GROUP BY CITY,MAKE ORDER BY CITY,MAKE)
SELECT CITY,SUM(PEOPLE),WMSYS.WM_CONCAT(MAKE) from TEST GROUP BY CITY
==========================================================
相关关键字:
1.sys_connect_by_path 函数主要作用是可以把一个父节点下的所有子节点通过某个字符进行区分
2.start with ... connect by prior ... 递归实现,如
start with pid= 1 connect by prior pid = id
//父id=子id 正树型结构 子id=父id 倒树型结构
上面的SQL中注意
start with T.CITY = T2.CITY connect by prior numberid = numberid+1
与start with T.CITY = T2.CITY connect by prior numberid+1 = numberid的区别
3.REVERSE字符串反转
===========================================================
回顾下其他:
1.Group By, Having, Where, Order by几个语句的执行顺序。一个SQL语句往往会产生多个临时视图,那么这些关键字的执行顺序就非常重要了,因为你必须了解这个
相关文档:
Oracle中的归档日志(Archive Log)
文章分类:数据库
在Oracle中,数据一般是存放在数据文件中,不过数据库与Oracle最大的区别之一就是数据库可以在数据出错的时候进行恢复。 这个也就是我们常见的Oracle中的重做日志(REDO FILE)的功能了。在重做日志分成2部分,一个是在线重做日志文件,另外一个就是归档日志文件。
......
select * from (select pro_id, sum(decode(month, '01', summ)) one,
sum(decode(month, '02', summ)) two,
&nb ......
@echo off
:dosmenu
REM 选择菜单
echo Windows 服务启动或关闭 By hope 2008年2月7日
echo.
echo [1]启动Sql Server2005 [2]关闭Sql Server2005
echo [3]启动Oracle9i [4]关闭Oracle9i
echo.
echo ......
-----------------------------------------------------------------------------------
DOS:
1. sqlplus
2.
用户名:sqlplus 、conn
密码:as sysdba 、as sysdba
解锁:
3. ALTER USER DBSNMP ACCOUNT UNLOCK;
解锁:system
4. alter user system identified by manage ......