函数命名空间管理器
注意 目前提供外部数据源函数(外部函数)的注册管理及下推的体验功能,此特性还在开发中,一些接口和配置项在后续的版本中可能会有改动。
函数命名空间管理器介绍
函数命名空间管理器是用来管理外部函数的,各个connector注册的外部函数(当前只支持标量函数)会在此空间管理。 一个函数命名空间表示为 catalog.schema
(例如:mysqlfun.default
),可以理解为函数定义存储的模式,不过此模式只能用于函数,不支持表或视图之类。 每个函数,不管是built in
函数的还是外部注册的外部函数,都属于一个格式为catalog.schema
的函数命名空间。 外部类型函数的全引用名为函数命名空间加上函数名(例如:mysqlfun.default.func
)。
所有built in
函数的使用方式为直接使用函数名,如:select count(*) from ...
。外部函数需要使用全引用名,如:select mysqlfun.default.format(...) from ...
。 每个函数命名空间管理器与一个catalog
关联,并且管理此catalog
下的所有函数。 建议不使用实际connector_catalog
名称作为函数命名空间管理器catalog
。
加载函数命名空间管理器
当要加载一个名称为mysqlfun
的函数命名空间管理器来管理名称为mysqlfun
的catalog
下的所有函数, 我们可以添加一个名称为 etc/function-namespace/mysqlfun.properties
的文件, 同时,请在文件中写入如下配置内容:
function-namespace-manager.name=memory
supported-function-languages=JDBC
当前仅支持类型为memory
函数命名空间管理器,memory
类型的函数命名空间管理器在系统重启后,需要重新加载外部函数信息。 配置项supported-function-languages
表明当前函数命名空间管理器实例支持的外部函数种类,你可以自己定义注册类型,此项参数需要用户定义的外部函数注册信息一致。 当前我们仅支持JDBC
。
加载多个函数命名空间管理器
当需要管理属于不同catalog
的外部函数时,我们需要在etc/function-namespace
目录下配置多个文件名不同的文件来加载多个函数命名空间管理器分别管理属于不同catalog
的外部函数。
外部函数注册到函数命名空间管理器
当前openLooKeng系统支持通过Jdbc Connector注册外部函数。具体请参考 外部函数注册
外部函数下推到数据源执行
openLooKeng系统支持外部函数通过Jdbc Connector下推到数据源执行。具体请参考 外部函数注册。
注意 外部函数仅支持下推到数据源执行。 如果一个外部函数不能下推到数据源,则当前的包含外部函数调用的查询将会失败。