Documentation Home
MySQL 9.3 C API Developer Guide
Download this Manual
PDF (US Ltr) - 1.4Mb
PDF (A4) - 1.4Mb


5.4.4 mysql_change_user()

boolmysql_change_user(MYSQL *mysql,                  const char *user,                  const char *password,                  const char *db)

Description

Changes the user and causes the database specified bydb to become the default (current) database on the connection specified bymysql. In subsequent queries, this database is the default for table references that include no explicit database specifier.

mysql_change_user() fails if the connected user cannot be authenticated or does not have permission to use the database. In this case, the user and database are not changed.

Pass adb parameter ofNULL if you do not want to have a default database.

This function resets the session state as if one had done a new connect and reauthenticated. (SeeSection 3.6.8, “Automatic Reconnection Control”.) It always performs aROLLBACK of any active transactions, closes and drops all temporary tables, and unlocks all locked tables. It resets session system variables to the values of the corresponding global system variables, releases prepared statements, closesHANDLER variables, and releases locks acquired withGET_LOCK(). Clears any current query attributes defined as a result of callingmysql_bind_param(). These effects occur even if the user did not change.

To reset the connection state in a more lightweight manner without changing the user, usemysql_reset_connection().

Return Values

Zero for success. Nonzero if an error occurred.

Errors

The same that you can get frommysql_real_connect(), plus:

Example

if (mysql_change_user(&mysql, "user", "password", "new_database")){   fprintf(stderr, "Failed to change user.  Error: %s\n",           mysql_error(&mysql));}