龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > 数据库类 > Oracle 技术 >

详解如何在Oracle中连接输出结果

时间:2011-04-12 23:18来源:未知 作者:admin 点击:
分享到:
一个偶然的机会,看到ASK TOM上的一个问题( http://asktom.oracle.com/pls/asktom/f?p=100:11:0::::P11_QUESTION_ID:229614022562 ),是关于查询结果字符串连接的。下图是对一个视图(视图代码附后,全部操作

一个偶然的机会,看到ASK TOM上的一个问题(http://asktom.oracle.com/pls/asktom/f?p=100:11:0::::P11_QUESTION_ID:229614022562),是关于查询结果字符串连接的。下图是对一个视图(视图代码附后,全部操作是在Oracle 10g中的HR schema中完成的)进行查询得到的常见的结果。

department ename

marketing  hartstein

marketing  fay

purchasing raphaely

purchasing khoo

...

it         hunold

it         ernst

...

但是也可能遇到需要下面这样的结果。

department ename

purchasing raphely,khoo,baida,tobias,himuro,colmenares

it         hunold,ernst,austin,pataballa,lorentz

marketing  hartstein,fay

CREATEORREPLACEVIEWd_employeeAS

SELECTd.department_name department,

e.last_name ename

FROMdepartments d,

employees e

WHEREd.department_id = e.department_idAND

d.department_nameIN('IT','Marketing','Purchasing');

为此,Tom大师提供了两种解决方案,如下:

方法一:

使用静态的SQL从表中选出需要进行连接的所有数据。

CREATEORREPLACEFUNCTIONCONCAT(P_DEPINVARCHAR2)RETURNVARCHAR2IS

L_STRVARCHAR2(200)DEFAULTNULL;

L_SEPVARCHAR2(200)DEFAULTNULL;

BEGIN

FORRCIN(SELECTENAMEFROMD_EMPLOYEEWHEREDEPARTMENT = P_DEP)LOOP

L_STR := L_STR || L_SEP || RC.ENAME;

L_SEP :=',';

ENDLOOP;

RETURNL_STR;

END;

使用下列查询语句查询:

SELECTd.department, hr.concat(d.department) employees

FROMd_employee d

GROUPBYdepartment;

方法二:

使用动态SQL,传入关键列(需求中的department)和那一列的一个值,以及需要实际进行连接的列(需求中的ename)以及表。

精彩图集

赞助商链接