Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
360 views
in Technique[技术] by (71.8m points)

hana - SQL Script to get Calculation View_name and its rowcount

I am looking for a query where I can get all calculation view names and its Rowcount.

SELECT "TABLE_NAME","RECORD_COUNT"

FROM "SYS"."M_TABLES" WHERE SCHEMA_NAME = '';

This query works for tables.I need same kind of query for calculation views.

question from:https://stackoverflow.com/questions/65641457/sql-script-to-get-calculation-view-name-and-its-rowcount

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

Since calculation view is essentially a composition of multiple objects with some complex logic, there's no predefined rowcount per view:

  • It should not be computed, because it depends on the underlying data, and there's no reason to recalculate it every time the data is changed.
  • I do not know, how does HANA use that count for table, but for calculation view it has no practical meaning: calculation view result is always build from scratch at the execution time, where you'll have the rowcount at the final step.
  • Because calculation view is not a "plain" object, but more like a table-valued function, which can have input parameters and produce the results based on that parameters, you have no ability to calculate the rowcount for parametrized view.

To get list of all calculation views with fully-qualified names you can use:

select
  '"' || schema_name || '"."'
    || catalog_name || '/'
    || cube_name || '"' as fullname
from _sys_bi.bimc_all_cubes

To get list of parametrized calculation views you can use:

select *
from _sys_bi.bimc_variable

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...