如何得到数据库表中的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'
) )
 

 

 

 

 

 

你可能感兴趣的:(oracle,sql)