Поскольку я впервые пишу UDF, я попытался написать простой UDF, чтобы вернуть тот же аргумент, который передается в UDF.
код, как показано ниже:
#include <stdlib.h>
#include <stdio.h>
#include <string>
#include <cstring>
#include <mysql.h>
#include <ctype.h>
#include <my_global.h>
#include <my_sys.h>
using namespace std;
extern "C" my_bool get_arg_init(UDF_INIT *initid, UDF_ARGS *args,
char *message)
{
if ( ( args->arg_count != 1 ) || ( args->arg_type[0] != STRING_RESULT ) )
{
strcpy( message, "Wrong argument type." );
return 1;
}
return 0;
}
extern "C" void get_arg_deinit(UDF_INIT *initid)
{
//nothing to free here
}
extern "C" char *get_arg(UDF_INIT *initid, UDF_ARGS *args,
char *result, unsigned long *length,
char *is_null, char *error)
{
std::string str = args->args[0]; // get the first argument passed
memcpy(result, str.c_str(), str.size()); // copy argument value into result buffer
*length = str.size(); // set length
return result;//return the same argument
}
Моя таблицас данными как;
SELECT c_name FROM tbl;
Это вернет данные как:
# c_name
amogh bharat shah
viraj
Если я выполню запрос с использованием UDF:
SELECT get_arg(c_name) FROM tbl;
Возвращает:
# get_arg(c_name)
amogh bharat shah
viraj bharat shah
Похоже, что первые 5 символов второй строки заменяются фактическими данными строки, а другая часть строки является мусором из первой строки.
ПочемуБывает?и что я должен изменить в функции, чтобы избежать наложения строки?