使用 LookML 创建所需的过滤器

您可以直接在 LookML 中指定过滤器行为,帮助用户策划过滤器体验。例如,您可以添加大多数用户在探索中会使用的实用过滤条件,也可以添加默认过滤条件,以降低查询导致数据库资源过载的风险。

本页简要介绍了会影响所有用户过滤的各 LookML 参数。

创建用户可以更改的过滤条件

下表列出了为所有用户设置可见探索级过滤条件的 LookML 参数。用户在浏览和查看 Looks 时可以看到过滤器并更改过滤器的值,但无法移除过滤器。这些过滤条件也适用于信息中心,不过用户无法通过信息中心查看或更改过滤条件的值,除非您同时创建了信息中心过滤条件

LookML 参数 范围 是否向用户显示? 可由用户修改吗? 说明
always_filter 探索 使用 always_filter LookML 参数为所有用户设置探索级别的过滤条件。用户可以查看过滤器并更改其默认值,但无法将其从“探索”中移除。
conditionally_filter 探索 使用 conditionally_filter LookML 参数为所有用户设置探索级别的过滤条件。与 always_filter 类似,用户可以查看过滤条件并更改其默认值。不过,与 always_filter 相反,如果特定字段被过滤,用户可以移除使用 conditionally_filter 指定的过滤器。

创建用户无法更改的过滤器

下表列出了为所有用户设置隐藏探索级别的过滤器的 LookML 参数。用户无法更改过滤条件,并且过滤将应用到每个查询的 SQL 中。这些过滤条件也适用于“外观”和“信息中心”。

LookML 参数 范围 是否向用户显示? 可由用户修改吗? 说明
sql_always_where 探索 有时 使用 sql_always_where LookML 参数,为“探索”功能生成的所有 SQL 查询的“WHERE”子句设置探索级别的查询限制。用户将无法更改过滤条件,并且只有在拥有查看生成的查询 SQL 的权限时才能看到过滤条件。
sql_always_having 探索 有时 使用 sql_always_having LookML 参数,为“探索”功能生成的所有 SQL 查询的“HAVING”子句设置探索级别的查询限制。与 sql_always_where 一样,用户将无法更改过滤条件,并且只有在拥有查看生成的查询 SQL 的权限时才能看到过滤条件。
sql_where 加入 有时 当查询中包含指定的联接时,使用 sql_where LookML 参数为通过“探索”生成的所有 SQL 查询的 WHERE 子句设置探索级查询限制。与 sql_always_where 一样,用户将无法更改过滤条件,并且只有在拥有查看生成的查询 SQL 的权限时才能看到过滤条件。
access_filter 探索 有时 使用 access_filter LookML 参数,针对“探索”功能生成的所有 SQL 查询的“WHERE”子句设置特定于探索的用户级别的查询限制。与 sql_always_where 一样,用户将无法更改过滤条件,并且只有在拥有查看生成的查询 SQL 的权限时才能看到过滤条件。但是,与 sql_always_where 相反,过滤条件由每个用户的用户属性值决定。

禁止用户过滤字段

下表列出了用于防止对各个字段进行过滤的 LookML 参数。

LookML 参数 范围 是否向用户显示? 可由用户修改吗? 说明
can_filter 字段 使用 can_filter LookML 参数来指定是否可以过滤字段。如需对某个字段进行过滤,请将 can_filter: no 行添加到该字段。这也可防止该字段在细目菜单中进行过滤。
skip_drill_filter 字段 使用 skip_drill_filter LookML 参数指定是否可以在细目菜单中过滤字段。为避免对细目菜单中的字段进行过滤,请在该字段中添加 skip_drill_filter: yes 行。在其他地理位置,此字段仍可作为过滤条件。