Oracle数据库单表循环提取输出
现在有如下的表,名称为Test表:
ydid sws_dm sws_mc ry_dm ry_mc
1 1 第一税务所 100 张飞
2 1 第一税务所 101 赵云
3 1 第一税务所 102 马超
4 1 第一税务所 103 黄忠
5 1 第一税务所 104 关羽
6 2 第二税务所 200 程昱
7 2 第二税务所 201 贾诩
8 2 第二税务所 202 郭嘉
9 2 第二税务所 203 荀彧
10 2 第二税务所 204 荀攸
11 3 第三税务所 300 司马懿
12 3 第三税务所 301 曹洪
13 3 第三税务所 302 曹仁
14 3 第三税务所 303 夏侯渊
15 3 第三税务所 304 阿速达
16 4 第四税务所 401 黄月英
17 4 第四税务所 402 庞统
18 4 第四税务所 403 马岱
19 4 第四税务所 404 刘备
20 5 第五税务所 500 陆逊
想形成如下的表结构,就是以sws_dm字段进行过滤,得出人员总数统计和人员名称:
sws_dm sws_mc ry_mc 总
1 第一税务所 张飞;赵云;马超;黄忠;关羽 5
2 第二税务所 程昱;贾诩;郭嘉;荀彧;荀攸 5
3 第三税务所 司马懿;曹洪;曹仁;夏侯渊;阿速达 5
4 第四税务所 黄月英;庞统;马岱;刘备 4
5 五税务所 陆逊 1
从上面,我们的出两种解决方法(在Oracle 11G中):
select sws_dm, sws_mc,
max(replace(substr(sys_connect_by_path(ry_mc, '*'), 2),'*',';')),count(*) 总人数
from(
select sws_dm, sws_mc,ry_mc,
dense_rank()over(order by sws_dm) + row_number()over(order by sws_dm) rid,
row_number() over (partition by sws_dm order by sws_dm) nid
from tab)
start with nid = 1
connect by prior rid = rid - 1
GROUP BY sws_dm,sws_mc;
在Oracle 10G中的语句如下:
select sws_dm, sws_mc, replace(wm_concat(ry_mc),',',';')ry_mc,count(*) 总人数
from tab
group by sws_dm, sws_mc;
然后另外一个方法就是利用SQL函数来解决:
具体做法如下:
create or replace FUNCTION JYH_ZHRY(BMID IN VARCHAR2)
---------------------------------------------------------------
--★ 将定位表里的数据转成单行
--★ WRITTEN BY XIASHITONG
---------------------------------------------------------------
RETURN VARCHAR2 IS
CURSOR C_ZBID IS
SELECT A.Ry_Mc || ';' Ry_Mc
FROM DB_QPGL.JYH_SYJKFK_YDQK A
WHERE A.Sws_Dm =BMID;
V_SQL VARCHAR2(5000) := '';
BEGIN
FOR C_R IN C_ZBID LOOP
V_SQL := V_SQL || C_R.Ry_Mc;
END LOOP;
IF V_SQL IS NOT NULL THEN
V_SQL := RTRIM(V_SQL, ',');
END IF;
RETURN V_SQL;
END;
然后在ORACLE中进行SQL语句的调用:
Select SWS_MC,COUNT(1),SWS_DM SL,DB_QPGL.JYH_ZHRY(SWS_DM) FROM DB_QPGL.JYH_SYJKFK_YDQK GROUP BY SWS_MC,SWS_DM
以下是转来的一片文章,大体上说明oracle的Function的运用:
方法一:帶入与表同形态的参数
CREATE OR REPLACE FUNCTION F_Get_Cust_Name (V_NO IN CUSTOMER.NO%TYPE,V_COMPNO IN CUSTOMER.COMPNO%TYPE)
RETURN CUSTOMER.NAME%TYPE
IS
V_NAME CUSTOMER.NAME%TYPE;
BEGIN
SELECT CUSTOMER.NAME INTO V_NAME
FROM CUSTOMER
WHERE
NO=V_NO AND COMPNO=V_COMPNO ;
RETURN V_NAME;
EXCEPTION WHEN NO_DATA_FOUND THEN RETURN ' '; ---錯誤回空白
END;
方法二:带入自定义类型的参数
CREATE OR REPLACE FUNCTION F_Get_Cust_Name (V_NO IN VARCHAR2,V_COMPNO IN VARCHAR2)
RETURN VARCHAR2
IS
V_NAME VARCHAR2;
BEGIN
SELECT CUSTOMER.NAME INTO V_NAME
FROM CUSTOMER
WHERE
NO=V_NO AND COMPNO=V_COMPNO ;
RETURN V_NAME;
EXCEPTION WHEN NO_DATA_FOUND THEN RETURN ' '; ---錯誤回空白
END;
例:
--1为正确登录
--2为密码不正确
--3为账户不存在
--返回数值型
create or replace function GetAccount(acc_id in MEMBERS.ACCOUNT_ID%type,acc_pwd in MEMBERS.ACCOUNT_PASSWORD%type)
return number
is
v_result number;
v_count number;
v_acc_pwd MEMBERS.ACCOUNT_PASSWORD%type;
begin
select count(*) as count, MEMBERS.ACCOUNT_PASSWORD into v_count,v_acc_pwd
from MEMBERS
where MEMBERS.ACCOUNT_ID=acc_id
group by MEMBERS.ACCOUNT_PASSWORD;
if v_count>0
then
if v_acc_pwd=acc_pwd then
v_result:=1;
else
v_result:=2;
end if;
else
v_result:=3;
end if;
return v_result;
EXCEPTION WHEN NO_DATA_FOUND THEN RETURN 3;
end;
Oracle数据库单表循环提取输出的更多相关文章
- oracle数据库单表查询
今天给大家分享的是关于数据库的单表查询,像单表查询/多表查询/分组查询/子查询,这些方法的使用在实际项目过程中会经常用到,作为一名合格的测试人员如果不会数据库那肯定是不行的,行走江湖可能随时会面临被侮 ...
- Mariadb/MySQL数据库单表查询基本操作及DML语句
Mariadb/MySQL数据库单表查询基本操作及DML语句 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一数据库及表相关概述 1>.数据库操作 创建数据库: CREATE ...
- WPF根据Oracle数据库的表,生成CS文件小工具
开发小工具的原因: 1.我们公司的开发是客户端用C#,服务端用Java,前后台在通讯交互的时候,会用到Oracle数据库的字段,因为服务器端有公司总经理开发的一个根据Oracle数据库的表生成的cla ...
- oracle查询单表占用空间的大小
oracle查询单表占用空间的大小 SELECT segment_name AS TABLENAME, BYTES B, BYTES KB, BYTES MB FROM user_segments w ...
- 定时从远程的数据库中取数据,然后把取出来的数据插入或更新本地的oracle数据库的表
最近项目中有一种需求: 大致需求是这样的 通过给定的 用户名和密码 要定时从远程的数据库中取数据,然后把取出来的数据插入或更新本地的oracle数据库的表 项目的结构式struts1 hibernat ...
- PowerDesigner连接Oracle数据库建表序列号实现自动增长
原文:PowerDesigner连接Oracle数据库建表序列号实现自动增长 创建表就不说了.下面开始介绍设置自动增长列. 1 在表视图的列上创建.双击表视图,打开table properties — ...
- Oracle 数据库整理表碎片
Oracle 数据库整理表碎片 转载:http://kyle.xlau.org/posts/table-fragmentation.html 表碎片的来源 当针对一个表的删除操作很多时,表会产生大量碎 ...
- mysql数据库单表只有一个主键自增id字段,ibatis实现id自增
mysql数据库单表只有一个主键自增id字段,ibatis实现id自增 <insert id="autoid"> insert into user_id ...
- Oracle数据库创建表是有两个约束带有默认索引
Oracle数据库创建表是有两个约束带有默认索引.1.主键primary Key:唯一索引.非空2.唯一Unique:唯一索引,可以是空值如果没有设定主键和唯一约束,表中不会有默认索引的. 建立主键/ ...
随机推荐
- 从0开始学习Hadoop(1) 环境准备 Win7环境+VirtureBox+Ubuntu
虚拟机:VirtureBox 3.18 下载地址: https://www.virtualbox.org/ 操作系统:Ubuntu 版本:ubuntu-15.04-desktop-amd64.iso ...
- linux文件名乱码时删除或改名的方式(转载)
转自:http://www.linuxsa.cn/when-linux-file-name-topsy-turvy-deleted-or-renamed.html linux文件名乱码时删除或改名的方 ...
- E201700525-hm
skeleton n. 骨骼; (建筑物等的) 骨架; 梗概; 骨瘦如柴的人(或动物);adj. 骨骼的; 骨瘦如柴的; 概略的; 基本的; cloud n. 云; 云状物; invoke ...
- 计蒜课--2n皇后、n皇后的解法(一般操作hhh)
给定一个 n*nn∗n 的棋盘,棋盘中有一些位置不能放皇后.现在要向棋盘中放入 nn 个黑皇后和 nn个白皇后,使任意的两个黑皇后都不在同一行.同一列或同一条斜线(包括正负斜线)上,任意的两个白皇后都 ...
- Codeforces Round #325D (Div. 2) (DP)
题目链接: D. Phillip and Trains 分析:dp 我们先初始化,dp[i]表示当前列第i行是否可达,r[i]表示上一个dp值,接下来从头搜到尾 如果该位置满足s[i+1]=='.'且 ...
- 立体渲染 Volumetric Rendering
基础概念 在3D游戏引擎中,球体.立方体以及所有其它复杂的集合体都是由三角面片组成的.引擎只会渲染物体的表面,比如球体,半透明物体等.整个世界由各种空壳构成. 立体渲染(Volumetric Rend ...
- python pip安装第三方模块
一.pip工具使用 安装windows版本python,自带pip工具.2者路径相同. 如果设置了环境路径,可以直接在命令提示符窗口下尝试运行pip.如果没有设置环境路径,可以先cd命令到pip工具的 ...
- 一条SQL语句是如何执行的?--Mysql45讲笔记记录 打卡day1
写在前面的话:回想以前上班的时候,空闲时间还是挺多的,但是都荒废了.如今找工作着实费劲了.但是这段时间在极客时间买了mysql45讲,就好像发现了新大陆一样,这是我认真做笔记的第一天,说实话第一讲我已 ...
- Luogu P1144 最短路计数 【最短路】 By cellur925
题目传送门 常规的最短路计数问题:注意有重边(重边不用理,看样例),自环(读入时过滤). 另外这个无向图没有权,其实可以直接bfs做,但考虑到以后带权的情况,按spfa走了. 水题被卡了三次(嘤嘤嘤 ...
- 题解报告:NYOJ #311完全背包(恰好装满)
描述: 直接说题意,完全背包定义有N种物品和一个容量为V的背包,每种物品都有无限件可用.第i种物品的体积是c,价值是w.求解将哪些物品装入背包可使这些物品的体积总和不超过背包容量,且价值总和最大.本题 ...