如何得到数据库表中的blob的大小

项目中要有一个功能点,即要把数据库存放的数据的大小返回给相应的用户,而在数据库表中有blob字段。

How can we query the size of blob?

 

假定数据库中的表名为user,得到整个表的大小的sql如下

SELECT sum( bytes)/1024/1024 size_in_MB
FROM user_segments

WHERE (segment_name = 'user'

OR segment_name in (
SELECT segment_name

FROM user_lobs

WHERE table_name = 'user'
UNION

SELECT index_name
FROM user_lobs

WHERE table_name = 'user'

) )

 

具体到blob的大小,oracle将blob字段分为lobsegment 和lob index.利用下面的sql可以清晰的看到所要查询的大小。

 

SELECT segment_name, segment_type, bytes/1024/1024 size_in_MB

FROM user_segments

WHERE (segment_name = 'user'

OR segment_name in (
SELECT segment_name

FROM user_lobs

WHERE table_name = 'user'
UNION

SELECT index_name
FROM user_lobs

WHERE table_name = 'user'
) )
 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值