1
0
mirror of https://github.com/mariadb-corporation/mariadb-connector-c.git synced 2025-08-08 14:02:17 +03:00

CONC-691: Obtain sql statement from statement handle

Added an option STMT_ATTR_SQL_STATEMENT in API function
mariadb_stmt_attr_get which returns a MARIADB_CONST_STRING
structure which contains SQL statement from last
mysql_stmt_prepare() call.
This commit is contained in:
Georg Richter
2024-12-12 12:07:34 +01:00
parent 6ca0574b7b
commit 3794a86544
4 changed files with 59 additions and 4 deletions

View File

@@ -69,7 +69,8 @@ enum enum_stmt_attr_type
STMT_ATTR_STATE, STMT_ATTR_STATE,
STMT_ATTR_CB_USER_DATA, STMT_ATTR_CB_USER_DATA,
STMT_ATTR_CB_PARAM, STMT_ATTR_CB_PARAM,
STMT_ATTR_CB_RESULT STMT_ATTR_CB_RESULT,
STMT_ATTR_SQL_STATEMENT
}; };
enum enum_cursor_type enum enum_cursor_type
@@ -204,6 +205,7 @@ struct st_mysql_stmt
ps_result_callback result_callback; ps_result_callback result_callback;
ps_param_callback param_callback; ps_param_callback param_callback;
size_t request_length; size_t request_length;
MARIADB_CONST_STRING sql;
}; };
typedef void (*ps_field_fetch_func)(MYSQL_BIND *r_param, const MYSQL_FIELD * field, unsigned char **row); typedef void (*ps_field_fetch_func)(MYSQL_BIND *r_param, const MYSQL_FIELD * field, unsigned char **row);

View File

@@ -971,7 +971,7 @@ static MARIADB_CONST_STRING null_const_string= {0,0};
/*************************************************************************** /***************************************************************************
** Allocate a string copy on memroot ** Allocate a string copy on memroot
***************************************************************************/ ***************************************************************************/
static MARIADB_CONST_STRING ma_const_string_copy_root(MA_MEM_ROOT *memroot, MARIADB_CONST_STRING ma_const_string_copy_root(MA_MEM_ROOT *memroot,
const char *str, const char *str,
size_t length) size_t length)
{ {

View File

@@ -80,6 +80,9 @@ typedef struct
} MADB_STMT_EXTENSION; } MADB_STMT_EXTENSION;
static my_bool net_stmt_close(MYSQL_STMT *stmt, my_bool remove); static my_bool net_stmt_close(MYSQL_STMT *stmt, my_bool remove);
extern MARIADB_CONST_STRING ma_const_string_copy_root(MA_MEM_ROOT *memroot,
const char *str,
size_t length);
static my_bool is_not_null= 0; static my_bool is_not_null= 0;
static my_bool is_null= 1; static my_bool is_null= 1;
@@ -1186,6 +1189,9 @@ unsigned long long STDCALL mysql_stmt_affected_rows(MYSQL_STMT *stmt)
my_bool STDCALL mysql_stmt_attr_get(MYSQL_STMT *stmt, enum enum_stmt_attr_type attr_type, void *value) my_bool STDCALL mysql_stmt_attr_get(MYSQL_STMT *stmt, enum enum_stmt_attr_type attr_type, void *value)
{ {
switch (attr_type) { switch (attr_type) {
case STMT_ATTR_SQL_STATEMENT:
*(MARIADB_CONST_STRING *)value= stmt->sql;
break;
case STMT_ATTR_STATE: case STMT_ATTR_STATE:
*(enum mysql_stmt_state *)value= stmt->state; *(enum mysql_stmt_state *)value= stmt->state;
break; break;
@@ -1841,6 +1847,8 @@ int STDCALL mysql_stmt_prepare(MYSQL_STMT *stmt, const char *query, unsigned lon
sizeof(stmt_id), 1, stmt)) sizeof(stmt_id), 1, stmt))
goto fail; goto fail;
} }
stmt->sql= ma_const_string_copy_root(&stmt->mem_root, query, length);
if (mysql->methods->db_command(mysql, COM_STMT_PREPARE, query, length, 1, stmt)) if (mysql->methods->db_command(mysql, COM_STMT_PREPARE, query, length, 1, stmt))
goto fail; goto fail;
@@ -2398,10 +2406,16 @@ MYSQL_RES * STDCALL mysql_stmt_result_metadata(MYSQL_STMT *stmt)
my_bool STDCALL mysql_stmt_reset(MYSQL_STMT *stmt) my_bool STDCALL mysql_stmt_reset(MYSQL_STMT *stmt)
{ {
my_bool rc= 0;
if (stmt->stmt_id > 0 && if (stmt->stmt_id > 0 &&
stmt->stmt_id != (unsigned long) -1) stmt->stmt_id != (unsigned long) -1)
return mysql_stmt_internal_reset(stmt, 0); rc= mysql_stmt_internal_reset(stmt, 0);
return 0;
/* clear last sql statement */
stmt->sql.str= 0;
stmt->sql.length= 0;
return rc;
} }
const char * STDCALL mysql_stmt_sqlstate(MYSQL_STMT *stmt) const char * STDCALL mysql_stmt_sqlstate(MYSQL_STMT *stmt)

View File

@@ -5224,7 +5224,46 @@ end:
return error ? FAIL : OK; return error ? FAIL : OK;
} }
static int test_conc691(MYSQL *mysql)
{
MYSQL_STMT *stmt= mysql_stmt_init(mysql);
MARIADB_CONST_STRING sql;
const char *sql_stmt[]= {"SELECT 'test' FROM DUAL", "This will return an error", "SELECT 1 FROM DUAL"};
int rc, i;
rc= mysql_stmt_attr_get(stmt, STMT_ATTR_SQL_STATEMENT, &sql);
check_stmt_rc(rc, stmt);
FAIL_IF(sql.str, "Expected empty SQL string");
FAIL_IF(sql.length, "Expected length=0");
for (i=0; i < 3; i++)
{
rc= mysql_stmt_prepare(stmt, SL(sql_stmt[i]));
rc= mysql_stmt_attr_get(stmt, STMT_ATTR_SQL_STATEMENT, &sql);
check_stmt_rc(rc, stmt);
FAIL_IF(strncmp(sql.str, sql_stmt[i], strlen(sql_stmt[i])), "Wrong SQL statement");
FAIL_IF(sql.length != strlen(sql_stmt[i]), "Wrong statement length");
}
rc= mysql_stmt_reset(stmt);
check_stmt_rc(rc, stmt);
rc= mysql_stmt_attr_get(stmt, STMT_ATTR_SQL_STATEMENT, &sql);
check_stmt_rc(rc, stmt);
FAIL_IF(sql.str, "Expected empty SQL string");
FAIL_IF(sql.length, "Expected length=0");
mysql_stmt_close(stmt);
return OK;
}
struct my_tests_st my_tests[] = { struct my_tests_st my_tests[] = {
{"test_conc691", test_conc691, TEST_CONNECTION_DEFAULT, 0, NULL, NULL},
{"test_conc565", test_conc565, TEST_CONNECTION_DEFAULT, 0, NULL, NULL}, {"test_conc565", test_conc565, TEST_CONNECTION_DEFAULT, 0, NULL, NULL},
{"test_conc349", test_conc349, TEST_CONNECTION_DEFAULT, 0, NULL, NULL}, {"test_conc349", test_conc349, TEST_CONNECTION_DEFAULT, 0, NULL, NULL},
{"test_prepare_error", test_prepare_error, TEST_CONNECTION_NEW, 0, NULL, NULL}, {"test_prepare_error", test_prepare_error, TEST_CONNECTION_NEW, 0, NULL, NULL},