You've already forked mariadb-columnstore-engine
mirror of
https://github.com/mariadb-corporation/mariadb-columnstore-engine.git
synced 2025-10-24 10:12:58 +03:00
1.2 KiB
1.2 KiB
mcsv1_udaf Introduction
mcsv1_udaf is a C++ API for writing User Defined Aggregate Functions (UDAF) and User Defined Analytic Functions (UDAnF) for the MariaDB Columstore engine.
In Columnstore 1.2, functions written using this API must be compiled into the udfsdk and udf_mysql libraries of the Columnstore code branch.
The API has a number of features. The general theme is, there is a class that represents the function, there is a context under which the function operates, and there is a data store for intermediate values.
The steps required to create a function are:
- Decide on a
memory allocation <memory_allocation>
scheme. - Create a
header file <header_file>
for your function. - Create a
source file <source_file>
for your function. - Implement
mariadb udaf api <mariadb_udaf>
code. - Add the function to
UDAFMap <udafmap>
in mcsv1_udaf.cpp - Add the function to
CMakeLists.txt <cmakelists>
in ./utils/udfsdk Compile udfsdk <compile>
.Copy the compiled libraries <copylibs>
to the working directories.
In 1.2, Columnstore does not have a plugin framework, so the functions have to be compiled into the libraries that Columnstore already loads.