[转]oracle查询树类型

以下内容来自http://hi.baidu.com/suofang/blog/item/a58bdd5829d5e583800a1812.html(其中的图片可到这个地址查看)
connect by prior start with 经常会被用到一个表中存在递归关系的时候。比如我们经常会将一个比较复杂的目录树存储到一个表中。或者将一些部门存储到一个表中,而这些部门互相有隶属关系。这个时候你就会用到connect by prior start with。
典型的使用方法就是:
select * from table connect by prior cur_id=parent_id start with cur_id=???
例如:
a b
1 0
2 1
3 1
4 2
5 3
如果想查找a=2及其下面的所有数据,则:
select * from table connect by prior a=b start with a=2
a b
2 1
4 2
这些只是基础,皮毛。其实只要你灵活的构造查询语句。可以得出意想不到的结果。比如生成树每一个路径。
但是这些记录组成的树必须正常才可以。如果有互为父子的情况,就会出现循环错误!
示例:


表结构图

表数据
select * from tb_cus_area_cde
--子取父
select * from tb_cus_area_cde a
CONNECT BY PRIOR a.c_snr_area=a.c_area_cde START WITH a.c_area_cde='1040101'
--父取子
select * from tb_cus_area_cde a
CONNECT BY PRIOR a.c_area_cde=a.c_snr_area START WITH a.c_snr_area is null

*************************自己总结 还是看优快云吧,赛迪总是不好用http://writeblog.youkuaiyun.com/PostList.aspx*********************************

ORACLE查询树型关系(connect by prior start with)

有如下表结构:
create table TVideoSort
(
FsysId NVARCHAR2(32 char) not null,
FSortName NVARCHAR2(32 char),
FSortTopId NVARCHAR2(32 char),
FSortAddress number,
FSortIsList char(1),
constraint PK_TVIDEOSORT primary key (FsysId)
);


数据如下:


--子查父(通过子节点向根节点追朔.)
查询〔特下边〕的父节点
select FsysId,FSortName,FSortTopId,FSortAddress,FSortIsList from TVideoSort
start with FsysId='3703E5CD81E48D6BE040007F01001254'--这个是特下边的fsysid
connect by prior FSortTopId=FsysId
order by FsortAddress

结果


――父查子(通过根节点遍历子节点.)
查询〔特下边〕的子节点:结果
select FsysId,FSortName,FSortTopId,FSortAddress,FSortIsList
from TVideoSort start with FsysId='3703E5CD81E48D6BE040007F01001254' --这个是特下边的fsysid
connect by prior FsysId=FSortTopId order by FsortAddress


查询〔特长练习〕的子节点:结果
select FsysId,FSortName,FSortTopId,FSortAddress,FSortIsList
from TVideoSort start with FsysId='36AE4D68EC7D364CE040007F01000CA5'
connect by prior FsysId=FSortTopId order by FsortAddress


特别注意,两个查询只是FsysId=FSortTopId不同而已,即子查父则把FSortTopId做为主表放前面,父查子则把FsysId放前面作主表
<think>嗯,用户这次问的是Oracle数据库查询图片类型的方法。根据提供的三个引用材料,我需要整合相关信息。 引用[1]展示了包含BLOB和CLOB类型的表结构,其中imageblob存储二进制数据,imagebase64存储base64编码。特别注意到它使用了dbms_lob.substr函数来查询CLOB字段,这个函数对BLOB同样适用。 引用[2]主要讲索引机制,看似无关,但提到rowid快速定位,这提醒我处理大对象时要注意性能问题。引用[3]则给出了Java插入图片的示例,反向说明图片是以二进制形式存储的。 用户的核心需求是"查询方法",重点应该是如何检索和展示已存储的图片数据。考虑从三个层面回应:首先是基本查询(直接查BLOB/CLOB),然后是换输出(如base64或16进制),最后是优化建议(分片查询和索引)。 注意到引用[1]的示例代码有特殊字符义问题,比如"<"应该是"<",需要修正。同时要强调dbms_lob.substr的参数含义:第二个40000是截取字节数,第三个1是起始位置。 用户可能还隐含如何验证图片内容的需求,所以补充base64在线换的提示。索引建议虽然引用[2]未直接关联图片查询,但where条件检索时仍有价值。 </think>在Oracle数据库中查询图片类型数据(通常存储为BLOB或CLOB类型)的方法如下,结合引用内容进行说明: --- ### 一、基础查询方法 1. **直接查询BLOB/CLOB列** ```sql SELECT id, image, imagebase64 FROM youli.youli_image_test WHERE rownum < 4; -- 引用[1]中的表结构和查询示例 ``` * 此方法直接返回二进制大对象(BLOB)或字符大对象(CLOB),但需通过应用程序解析才能显示图片。 2. **分片读取大对象数据** 使用 `DBMS_LOB.SUBSTR` 函数分段读取,避免一次性加载过大数据: ```sql SELECT id, DBMS_LOB.SUBSTR(image, 4000, 1) AS image_part -- 每次读取4000字节 FROM youli.youli_image_test; -- 引用[1]中示例 ``` * **参数说明**: `4000`:截取字节数(BLOB)/字符数(CLOB) `1`:起始位置 --- ### 二、换为可读格式 1. **Base64编码输出(适用于CLOB列)** 若图片已存储为Base64(如引用[1]中的`imagebase64`列): ```sql SELECT id, imagebase64 FROM youli.youli_image_test; ``` * 可直接获取文本格式的Base64字符串,前端通过`<img src="data:image/png;base64,{{value}}">`渲染。 2. **将BLOB实时为Base64** 使用 `UTL_ENCODE.BASE64_ENCODE`: ```sql SELECT id, UTL_RAW.CAST_TO_VARCHAR2( UTL_ENCODE.BASE64_ENCODE(image) ) AS base64_data FROM youli.youli_image_test; ``` --- ### 三、优化查询性能 1. **添加索引** ```sql CREATE INDEX idx_image_id ON youli.youli_image_test(id); -- 引用[2]索引创建语法 ``` * 对频繁过滤的列(如ID)建立B树索引,加速定位记录,避免全表扫描[^2]。 2. **限制返回行数** 使用 `ROWNUM` 或 `FETCH FIRST` 减少数据传输量: ```sql SELECT * FROM youli.youli_image_test WHERE id = 'IMG001' FETCH FIRST 1 ROWS ONLY; -- 精确查询单张图片 ``` --- ### 四、应用层处理建议 1. **Java/Python 读取示例** 如引用[3]所示,应用程序需通过大对象API处理: ```java // Java 读取BLOB Blob imageBlob = resultSet.getBlob("image"); InputStream in = imageBlob.getBinaryStream(); ``` * 将二进制流换为图片对象输出。 --- ### 注意事项 1. **性能隐患** 直接查询未分片的BLOB会导致内存溢出,务必使用`DBMS_LOB.SUBSTR`分段操作[^1]。 2. **验证内容** 通过 `DBMS_LOB.GETLENGTH(image)` 检查图片大小是否完整。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值