|MicroCheapFx 4e436745ef Merging origin/master||6 months ago|
|include||6 months ago|
|src||6 months ago|
|test||6 months ago|
|.gitignore||6 months ago|
|.gitignore.orig||6 months ago|
|CMakeLists.txt||6 months ago|
|README.md||6 months ago|
|hello.so||6 months ago|
|setup.sh||6 months ago|
This is a simple demo to show maridb UDF mechanisms.
In order to follow this tutorial, you’ll need the following tools:
This UDF doesn’t do a real killer feature. It just return a “Hello” message to mariadb. But it is simple enough to understand how it works.
MariaDB [(none)]> SELECT hello('John Doe'); +-------------------+ | hello('John Doe') | +-------------------+ | Hello John Doe! | +-------------------+ 1 row in set (0.00 sec)
User Defined Functions are stored in dynamical shared libraries (.so files) and are sets of functions adding new possibilities to mariadb engine.
With them, you’ll be able to process data with C execution fuzzing speed or even be able to communicate with the rest of your operating system.
What is essential to understand is that they are external to mariadb. So in order to communicate with the engine, they need to communicate in a standard way with a predefined set of variables and functions.
Also, as they are only shared libraries, you won’t be able to debug them within mariadb. In order to fix that, we’ll write a little program in C, mocking mariadb engine. This program will also be a good unit testing set.