Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Free Learning
Arrow right icon
MySQL 5.1 Plugin Development
MySQL 5.1 Plugin Development

MySQL 5.1 Plugin Development: Extend MySQL to suit your needs with this unique guide into the world of MySQL plugins

eBook
$9.99 $28.99
Paperback
$48.99
Subscription
Free Trial
Renews at $19.99p/m

What do you get with Print?

Product feature icon Instant access to your digital eBook copy whilst your Print order is Shipped
Product feature icon Paperback book shipped to your preferred address
Product feature icon Download this book in EPUB and PDF formats
Product feature icon Access this title in our online reader with advanced features
Product feature icon DRM FREE - Read whenever, wherever and however you want
OR
Modal Close icon
Payment Processing...
tick Completed

Shipping Address

Billing Address

Shipping Methods
Table of content icon View table of contents Preview book icon Preview Book

MySQL 5.1 Plugin Development

Chapter 2. User Defined Functions

Way back in 1998, MySQL 3.21 introduced a framework that allowed users to create new SQL functions easily. It made it possible for developers to write their own functions in C/C++ and load them dynamically into the running server. The functions loaded within this framework were called User Defined Functions or UDFs.

Today not much has changed with UDFs, they are more stable and slightly more secure than they used to be, and they can be declared aggregate for use together with GROUP BY queries. However, many UDFs that worked in 1998 with MySQL 3.21.24 would still work at the time of writing in 2010, with MySQL 5.1.47.

MySQL UDFs are not part of the newer MySQL Plugin API, but there are future plans to make this happen. In the meantime, they can serve as an introduction to MySQL plugins. And sometimes UDFs can be used together with plugins to complement their functionality. In this chapter, we will cover creating User Defined Functions and write several of...

Writing UDFs


UDFs can be of two types, normal and aggregate. Normal UDFs take inputs and deliver an output just like an ordinary function in most programming languages. When run on a set of rows, they will return a result for every row. Aggregate UDFs take a group of rows, process each row, and produce a result at the end. In other words, they will return one result per group. Therefore, aggregate functions are useful for tasks such as adding up a group of values or calculating an average.

Whether MySQL considers a given UDF as an aggregate or a normal type depends on how it was installed. However, the API is somewhat different too, and we need to take care to install UDFs that use the aggregate API as aggregate and normal UDFs as normal. Otherwise they will not only fail to work correctly, but may as well crash the whole server.

Why write UDFs

There are several advantages and disadvantages to UDFs that we should be aware of. UDFs are much easier to develop than is hacking raw code into the...

A constant integer output UDF


To show the basic construction of a UDF we will start with a simple constant function that returns an integer. The output of this UDF will be the same no matter what arguments are passed to the UDF. To make the example a little more complex and to demonstrate the initid->ptr usage we will allocate a small amount of memory upon initialization to store our integer. This example will be called udf_staticexample:

#include <stdlib.h>
#include <string.h>
#include <mysql.h>

These are the standard includes needed for this example. The header mysql.h contains the structures and constants that we will use.

my_bool udf_staticexample_init(UDF_INIT *initid,
UDF_ARGS *args, char *message)
{

We are calling this UDF udf_staticexample so all functions need to be prefixed with this. We start with the udf_staticexample_init() function, which as we have seen before, prepares the UDF for execution in the context of an SQL statement.

long long *staticint =...

An integer echoing UDF


The next example is designed to show how to deal with inputs. It is similar to the previous one, but will demonstrate how to perform argument checking. As you remember, this check should happen in the initialization function, so that we can give a proper error message when there is a problem. We will call this UDF, udf_intexample, and will make it accept only one argument, which has to be an integer for the function to succeed:

#include <string.h>
#include <mysql.h>
my_bool udf_intexample_init(UDF_INIT *initid,
UDF_ARGS *args, char *message)
{

As before, we include everything needed for this example and create an initialization function with the same prefix as the function name.

if (args->arg_count != 1)
{
strcpy(message,
"udf_intexample() can only accept one argument");
return 1;
}

We want to ensure that only one argument is accepted for this UDF so we check that arg_count is 1. If it is not, we stick an error message into the message buffer and return...

A simple static text output UDF


Returning text in a MySQL UDF can be slightly more complex than dealing with numbers. MySQL gives us a memory buffer to use when returning a string but it is only 766 bytes long. This is fine for some tasks, but not big enough to hold a long string or a blob, so what we do is allocate our own buffer for this purpose. Either way, we need to tell MySQL how long the resulting string is.

The next piece of example code has two UDFs inside it, the first showing how to use the memory buffer that MySQL has given us and the second allocating its own memory. Both are simple UDFs which will just return the MySQL version number that UDF was compiled against:

#include <stdlib.h>
#include <string.h>
#include <mysql.h>
my_bool udf_textexample_init(UDF_INIT *initid,
UDF_ARGS *args, char *message)
{
initid->const_item = 1;
return 0;
}

As with previous examples we create the initialization function. We set initid->const_item to 1 here because the return...

A summing aggregate UDF


As discussed earlier in this chapter, aggregate UDFs are great for performing operations on groups of rows. Things work slightly differently here, we have a new keyword to use when installing UDFs and two extra functions to deal with individual rows and to clean up after every group of rows.

Let's write an aggregating UDF that will add up floating point numbers. We will call it udf_floatsum:

#include <stdlib.h>
#include <string.h>
#include <mysql.h>
my_bool udf_floatsum_init(UDF_INIT *initid, UDF_ARGS *args,
char *message)
{
double* float_total = malloc(sizeof(double));
*float_total = 0;
initid->ptr = (char*) float_total;

To aggregate we need an accumulator, a variable of the type double to keep the running totals as we are seeing rows one by one. Different queries invoking our UDF must have different running totals, in other words, initid->ptr is exactly what's needed. We allocate memory for one double and save a pointer to it in initid...

Further reading


There is a UDF repository run by Roland Bouman that contains various useful functions in both source and binary forms. This can be found at http://www.mysqludf.org/.

To make the UDF API even easier to use, Hartmut Holzgraefe, a MySQL Support Manager at Sun Microsystems, has created a UDF generator. This generates the source code for you based on an XML description of what the UDF should do. More information on this can be found at its PECL site at: http://pear.php.net/package/CodeGen_MySQL_UDF/

Summary


We can now see that writing a UDF is not too complex. MySQL has a lot of built-in functionality to help with the task. UDFs make a good compromise between easy and limited Stored Procedures and the ultimate power and complexity of modifying the source code of the MySQL server.

Left arrow icon Right arrow icon

Key benefits

  • A practical guide with working examples explained line by line
  • Add new functions to MySQL with User Defined Functions
  • Export information via SQL using the INFORMATION_SCHEMA plugins
  • Search within PDFs, MP3s, and images; offset user typing errors with fulltext parser plugins
  • Access your custom data formats with a storage engine plugin

Description

MySQL has introduced a Plugin API with its latest version – a robust, powerful, and easy way of extending the server functionality with loadable modules on the fly. But until now anyone wishing to develop a plugin would almost certainly need to dig into the MySQL source code and search the Web for missing bits of the information.This is the first book on the MySQL Plugin API. Written together with one of the Plugin API primary architects, it contains all the details you need to build a plugin. It shows what a plugin should contain and how to compile, install, and package it. Every chapter illustrates the material with thoroughly explained source code examples.Starting from the basic features, common to all plugin types, and the structure of the plugin framework, this book will guide you through the different plugin types, from simple examples to advanced ones. Server monitoring, full-text search in JPEG comments, typo-tolerant searches, getting the list of all user variables, system usage statistics, or a complete storage engine with indexes – these and other plugins are developed in different chapters of this book, demonstrating the power and versatility of the MySQL Plugin API and explaining the intricate details of MySQL Plugin programming.

Who is this book for?

If you are a MySQL application developer or a programmer who wants to interface with MySQL server, this book is for you. Basic knowledge of C/C++, SQL, and MySQL in particular is assumed in the book, but no deep familiarity with any of the topics is required.

What you will learn

  • Build and install a plugin, and learn how to package it for distributing separately from MySQL
  • Add new functions to MySQL using the UDF interface
  • Declare new MySQL status and configuration variables from a plugin, and use Daemon plugins for a simple push style server monitoring
  • Add a new table to the INFORMATION_SCHEMA that shows anything you like with an INFORMATION_SCHEMA plugin
  • Use fulltext parser plugins to tolerate user errors, and search for text in binary data formats, for example, JPEG, or text that is stored outside the database
  • Store and retrieve rows and convert your custom data format to what MySQL understands using the storage engine plugin
  • Create a parser that indexes comments from JPEG files using the libexif library
  • Understand how the indexing API works, and how to work around the incompatibilities between your indexing engine and MySQL expectations
  • Learn about new features of the Plugin API, available beyond MySQL 5.1
Estimated delivery fee Deliver to Turkey

Standard delivery 10 - 13 business days

$12.95

Premium delivery 3 - 6 business days

$34.95
(Includes tracking information)

Product Details

Country selected
Publication date, Length, Edition, Language, ISBN-13
Publication date : Aug 26, 2010
Length: 288 pages
Edition : 1st
Language : English
ISBN-13 : 9781849510608
Vendor :
MySQL
Category :
Tools :

What do you get with Print?

Product feature icon Instant access to your digital eBook copy whilst your Print order is Shipped
Product feature icon Paperback book shipped to your preferred address
Product feature icon Download this book in EPUB and PDF formats
Product feature icon Access this title in our online reader with advanced features
Product feature icon DRM FREE - Read whenever, wherever and however you want
OR
Modal Close icon
Payment Processing...
tick Completed

Shipping Address

Billing Address

Shipping Methods
Estimated delivery fee Deliver to Turkey

Standard delivery 10 - 13 business days

$12.95

Premium delivery 3 - 6 business days

$34.95
(Includes tracking information)

Product Details

Publication date : Aug 26, 2010
Length: 288 pages
Edition : 1st
Language : English
ISBN-13 : 9781849510608
Vendor :
MySQL
Category :
Tools :

Packt Subscriptions

See our plans and pricing
Modal Close icon
$19.99 billed monthly
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Simple pricing, no contract
$199.99 billed annually
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just $5 each
Feature tick icon Exclusive print discounts
$279.99 billed in 18 months
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just $5 each
Feature tick icon Exclusive print discounts

Frequently bought together


Stars icon
Total $29.97 $87.97 $58.00 saved
MySQL for Python
$54.99
Mastering phpMyAdmin 3.4 for Effective MySQL Management
$43.99
MySQL 5.1 Plugin Development
$48.99
Total $29.97$87.97 $58.00 saved Stars icon
Banner background image

Table of Contents

10 Chapters
Compiling and Using MySQL Plugins Chevron down icon Chevron up icon
User Defined Functions Chevron down icon Chevron up icon
Daemon Plugins Chevron down icon Chevron up icon
Information Schema Plugins Chevron down icon Chevron up icon
Advanced Information Schema Plugins Chevron down icon Chevron up icon
Full-text Parser Plugins Chevron down icon Chevron up icon
Practical Full-text Parsers Chevron down icon Chevron up icon
Storage Engine Plugins Chevron down icon Chevron up icon
HTML Storage Engine—Reads and Writes Chevron down icon Chevron up icon
TOCAB Storage Engine — Implementing Indexes Chevron down icon Chevron up icon

Customer reviews

Rating distribution
Full star icon Full star icon Full star icon Full star icon Full star icon 5
(2 Ratings)
5 star 100%
4 star 0%
3 star 0%
2 star 0%
1 star 0%
Giuseppe Maxia Nov 03, 2010
Full star icon Full star icon Full star icon Full star icon Full star icon 5
Highly recommended. If you want to develop MySQL extensions, buy this book. It's a must, written by two expert professionals who probably know more than anyone else on this matter. The book is full of practical examples explained with the theoretical information necessary to make it stick.
Amazon Verified review Amazon
Mark Callaghan Aug 05, 2011
Full star icon Full star icon Full star icon Full star icon Full star icon 5
I read this book last year and was impressed. It is written by experts so there is a lot of valuable information. But they also took the time, a huge amount of time, to write this so that it is easy to read. I don't know the editor but will thank him/her as well. [...]
Amazon Verified review Amazon
Get free access to Packt library with over 7500+ books and video courses for 7 days!
Start Free Trial

FAQs

What is the delivery time and cost of print book? Chevron down icon Chevron up icon

Shipping Details

USA:

'

Economy: Delivery to most addresses in the US within 10-15 business days

Premium: Trackable Delivery to most addresses in the US within 3-8 business days

UK:

Economy: Delivery to most addresses in the U.K. within 7-9 business days.
Shipments are not trackable

Premium: Trackable delivery to most addresses in the U.K. within 3-4 business days!
Add one extra business day for deliveries to Northern Ireland and Scottish Highlands and islands

EU:

Premium: Trackable delivery to most EU destinations within 4-9 business days.

Australia:

Economy: Can deliver to P. O. Boxes and private residences.
Trackable service with delivery to addresses in Australia only.
Delivery time ranges from 7-9 business days for VIC and 8-10 business days for Interstate metro
Delivery time is up to 15 business days for remote areas of WA, NT & QLD.

Premium: Delivery to addresses in Australia only
Trackable delivery to most P. O. Boxes and private residences in Australia within 4-5 days based on the distance to a destination following dispatch.

India:

Premium: Delivery to most Indian addresses within 5-6 business days

Rest of the World:

Premium: Countries in the American continent: Trackable delivery to most countries within 4-7 business days

Asia:

Premium: Delivery to most Asian addresses within 5-9 business days

Disclaimer:
All orders received before 5 PM U.K time would start printing from the next business day. So the estimated delivery times start from the next day as well. Orders received after 5 PM U.K time (in our internal systems) on a business day or anytime on the weekend will begin printing the second to next business day. For example, an order placed at 11 AM today will begin printing tomorrow, whereas an order placed at 9 PM tonight will begin printing the day after tomorrow.


Unfortunately, due to several restrictions, we are unable to ship to the following countries:

  1. Afghanistan
  2. American Samoa
  3. Belarus
  4. Brunei Darussalam
  5. Central African Republic
  6. The Democratic Republic of Congo
  7. Eritrea
  8. Guinea-bissau
  9. Iran
  10. Lebanon
  11. Libiya Arab Jamahriya
  12. Somalia
  13. Sudan
  14. Russian Federation
  15. Syrian Arab Republic
  16. Ukraine
  17. Venezuela
What is custom duty/charge? Chevron down icon Chevron up icon

Customs duty are charges levied on goods when they cross international borders. It is a tax that is imposed on imported goods. These duties are charged by special authorities and bodies created by local governments and are meant to protect local industries, economies, and businesses.

Do I have to pay customs charges for the print book order? Chevron down icon Chevron up icon

The orders shipped to the countries that are listed under EU27 will not bear custom charges. They are paid by Packt as part of the order.

List of EU27 countries: www.gov.uk/eu-eea:

A custom duty or localized taxes may be applicable on the shipment and would be charged by the recipient country outside of the EU27 which should be paid by the customer and these duties are not included in the shipping charges been charged on the order.

How do I know my custom duty charges? Chevron down icon Chevron up icon

The amount of duty payable varies greatly depending on the imported goods, the country of origin and several other factors like the total invoice amount or dimensions like weight, and other such criteria applicable in your country.

For example:

  • If you live in Mexico, and the declared value of your ordered items is over $ 50, for you to receive a package, you will have to pay additional import tax of 19% which will be $ 9.50 to the courier service.
  • Whereas if you live in Turkey, and the declared value of your ordered items is over € 22, for you to receive a package, you will have to pay additional import tax of 18% which will be € 3.96 to the courier service.
How can I cancel my order? Chevron down icon Chevron up icon

Cancellation Policy for Published Printed Books:

You can cancel any order within 1 hour of placing the order. Simply contact customercare@packt.com with your order details or payment transaction id. If your order has already started the shipment process, we will do our best to stop it. However, if it is already on the way to you then when you receive it, you can contact us at customercare@packt.com using the returns and refund process.

Please understand that Packt Publishing cannot provide refunds or cancel any order except for the cases described in our Return Policy (i.e. Packt Publishing agrees to replace your printed book because it arrives damaged or material defect in book), Packt Publishing will not accept returns.

What is your returns and refunds policy? Chevron down icon Chevron up icon

Return Policy:

We want you to be happy with your purchase from Packtpub.com. We will not hassle you with returning print books to us. If the print book you receive from us is incorrect, damaged, doesn't work or is unacceptably late, please contact Customer Relations Team on customercare@packt.com with the order number and issue details as explained below:

  1. If you ordered (eBook, Video or Print Book) incorrectly or accidentally, please contact Customer Relations Team on customercare@packt.com within one hour of placing the order and we will replace/refund you the item cost.
  2. Sadly, if your eBook or Video file is faulty or a fault occurs during the eBook or Video being made available to you, i.e. during download then you should contact Customer Relations Team within 14 days of purchase on customercare@packt.com who will be able to resolve this issue for you.
  3. You will have a choice of replacement or refund of the problem items.(damaged, defective or incorrect)
  4. Once Customer Care Team confirms that you will be refunded, you should receive the refund within 10 to 12 working days.
  5. If you are only requesting a refund of one book from a multiple order, then we will refund you the appropriate single item.
  6. Where the items were shipped under a free shipping offer, there will be no shipping costs to refund.

On the off chance your printed book arrives damaged, with book material defect, contact our Customer Relation Team on customercare@packt.com within 14 days of receipt of the book with appropriate evidence of damage and we will work with you to secure a replacement copy, if necessary. Please note that each printed book you order from us is individually made by Packt's professional book-printing partner which is on a print-on-demand basis.

What tax is charged? Chevron down icon Chevron up icon

Currently, no tax is charged on the purchase of any print book (subject to change based on the laws and regulations). A localized VAT fee is charged only to our European and UK customers on eBooks, Video and subscriptions that they buy. GST is charged to Indian customers for eBooks and video purchases.

What payment methods can I use? Chevron down icon Chevron up icon

You can pay with the following card types:

  1. Visa Debit
  2. Visa Credit
  3. MasterCard
  4. PayPal
What is the delivery time and cost of print books? Chevron down icon Chevron up icon

Shipping Details

USA:

'

Economy: Delivery to most addresses in the US within 10-15 business days

Premium: Trackable Delivery to most addresses in the US within 3-8 business days

UK:

Economy: Delivery to most addresses in the U.K. within 7-9 business days.
Shipments are not trackable

Premium: Trackable delivery to most addresses in the U.K. within 3-4 business days!
Add one extra business day for deliveries to Northern Ireland and Scottish Highlands and islands

EU:

Premium: Trackable delivery to most EU destinations within 4-9 business days.

Australia:

Economy: Can deliver to P. O. Boxes and private residences.
Trackable service with delivery to addresses in Australia only.
Delivery time ranges from 7-9 business days for VIC and 8-10 business days for Interstate metro
Delivery time is up to 15 business days for remote areas of WA, NT & QLD.

Premium: Delivery to addresses in Australia only
Trackable delivery to most P. O. Boxes and private residences in Australia within 4-5 days based on the distance to a destination following dispatch.

India:

Premium: Delivery to most Indian addresses within 5-6 business days

Rest of the World:

Premium: Countries in the American continent: Trackable delivery to most countries within 4-7 business days

Asia:

Premium: Delivery to most Asian addresses within 5-9 business days

Disclaimer:
All orders received before 5 PM U.K time would start printing from the next business day. So the estimated delivery times start from the next day as well. Orders received after 5 PM U.K time (in our internal systems) on a business day or anytime on the weekend will begin printing the second to next business day. For example, an order placed at 11 AM today will begin printing tomorrow, whereas an order placed at 9 PM tonight will begin printing the day after tomorrow.


Unfortunately, due to several restrictions, we are unable to ship to the following countries:

  1. Afghanistan
  2. American Samoa
  3. Belarus
  4. Brunei Darussalam
  5. Central African Republic
  6. The Democratic Republic of Congo
  7. Eritrea
  8. Guinea-bissau
  9. Iran
  10. Lebanon
  11. Libiya Arab Jamahriya
  12. Somalia
  13. Sudan
  14. Russian Federation
  15. Syrian Arab Republic
  16. Ukraine
  17. Venezuela