项目中要有一个功能点,即要把数据库存放的数据的大小返回给相应的用户,而在数据库表中有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'
) )