开发者

C/C++ program for checking MySQL connectivity and InnoDB plug-ins

I need a C/C++ program that connects to a MySQL server and checks if the InnoDB data store is installed on it.

The program sh开发者_开发知识库ould print the total number of disk writes by MySQL onto the InnoDB store.


/*
Below program is compiled using GCC and tested in Ubuntu 11.04 and    Maynot run properly run in windows because of header file.
Make sure MySQL is installed properly.
*/
 #include<stdio.h>  
 #include<string.h>
 #include<mysql.h>
 //#include<conio.h> //Uncomment if you are using windows
 int main()
 {
     MYSQL *connection;//pointer to connection string, MYSQL structure pointer
     MYSQL_RES *result;//pointer holds result
     MYSQL_ROW row;//stores a row  in result

     char *server = "localhost";//server is localhost since MySQL runs in same machine
     char *user = "root";//username to connect to DB
     char *password = "pass";//Password
     char *database = "blog";//DB name

     connection = mysql_init(NULL);//Getting ready for MySQL Connection

     if(!mysql_real_connect(connection, server, user, password, database,
     0, NULL, 0))//Establishing connection with parameters
     {
        fprintf(stderr, "%s\n", mysql_error(connection));//PRINT Error message 
        exit(1);//In case unable to connect quit
     }

     /*
       show engines will display all the engines available.Sample  Output 
       mysql> show engines;
       +------------+---------+------------------------------------    ----------------------------+--------------+------+------------+
       | Engine     | Support | Comment                                                          | Transactions | XA   | Savepoints |
       +------------+---------+------------------------------------ ----------------------------+--------------+------+------------+
       | InnoDB     | YES     | Supports transactions, row-level locking, and foreign keys     | YES          | YES  | YES        |
       | MRG_MYISAM | YES     | Collection of identical MyISAM  tables                          | NO           | NO   | NO         |
       | BLACKHOLE  | YES     | /dev/null storage engine (anything you write to it disappears) | NO           | NO   | NO         |
       | CSV        | YES     | CSV storage engine                                                  | NO           | NO   | NO         |
       | MEMORY     | YES     | Hash based, stored in memory, useful for temporary tables      | NO           | NO   | NO         |
       | FEDERATED  | NO      | Federated MySQL storage engine                                 | NULL         | NULL | NULL       |
       | ARCHIVE    | YES     | Archive storage engine                                         | NO           | NO   | NO         |
       | MyISAM     | DEFAULT | Default engine as of MySQL 3.23 with great performance         | NO           | NO   | NO         |
       +------------+---------+----------------------------------------------------------------+--------------+------+------------+
       8 rows in set (0.00 sec)


       */
       if(mysql_query(connection, "show engines"))
       {
            fprintf(connection, "%s\n", mysql_error(connection));
            exit(1);//EXit when query failed
       }

       result = mysql_use_result(connection);//fetch result pointer
       printf("\n --- Output ---- \n");
       while((row = mysql_fetch_row(result)) != NULL)//iterating over the result
       {
             if((strcmp(row[0], "InnoDB") == 0) && strcmp(row[1], "YES") == 0)
             printf("InnoDB engine is supported\n");
             break;
        }
        mysql_free_result(result);//Free the buffer 

        //To fetch Total writes
        if(mysql_query(connection, "show global status"))
        {
             fprintf(connection, "%s\n", mysql_error(connection));
             exit(1);//EXit when query failed
        }

        result = mysql_use_result(connection);//fetch result pointer
        while((row = mysql_fetch_row(result)) != NULL)//iterating over the result
        {
              if(strcmp(row[0], "Handler_write") == 0)
              printf("\nTotal Writes : %d\n", row[1]);
         }

         mysql_free_result(result);//Free the buffer 
         mysql_close(connection);//close the connection

         //getch(); //uncomment this line if you are using windows.
         return 0;
     }


/*
 Program    :InnoDB_checker.c
 Description:Write a C/C++ program that connects to a MySQL server and checks if the              InnoDB plug-in is installed on it.
        If so, your program should print the total number of disk writes by MySQL.
 Date       :7/09/2011
 Version    :1.0
 Author     :Venugopal Madathil*/
 /*Command to run the program: gcc -o output -I/usr/include/mysql/ -lmysqlclient InnoDB_checker.c -w */

#include<stdio.h>
#include<mysql.h>
#include<string.h>
int main(int argc,char *argv[])
{ 
        MYSQL *connection;
        MYSQL_RES *result;
        MYSQL_ROW *row;


//printf("\nI'm here\n");//Debugger
char *server = "localhost";//Since system itself acts as the server
//Credentials initialization
char *user = "root";
char *password = "pass";//Must 
char *database = "webyog";//Must be an existing database name
int numfields,Inno_flag=0,CSV_flag=0,c;
char choice;

do
{
    system("clear");//To clear the terminal screen
    printf("----------------------\nPlug-in checker\n");
    printf("----------------------\n");
    connection = mysql_init(NULL);//Allocates or initializes a MYSQL object suitable for mysql_real_connect,if NULL it returs a new object
    if(!mysql_real_connect(connection,server,user,password,database,0,NULL,0))//Connection establishment
    {
        printf("\nConnection error:");
        fprintf(stderr,"%s\n",mysql_error(connection));//Error
    }
    if(mysql_query(connection,"show engines"))
    {
        printf("\nQuery execution failed:");
        fprintf(stderr,"%s\n",mysql_error(connection));//Error
    }
    result = mysql_use_result(connection);//Fetching result
    numfields = mysql_num_fields(result);
    //printf("\nNumber of fields:%d\n",numfields);//Number of fields
    printf("What do you want to check?\nPress 1 for InnoDB\nPress 2 for CSV support\nYour choice: ");
    scanf("%d",&c);
    //
    while((row = mysql_fetch_row(result)) != NULL)//Iterating result row
            {
                if((strcmp(row[0], "InnoDB") == 0) && strcmp(row[1], "YES") == 0)//Innodb plug in checking
                        Inno_flag=1;
                    if((strcmp(row[0], "CSV") == 0) && strcmp(row[1], "YES") == 0)//CSV support checking
                        CSV_flag=1;
            }
    switch(c)
    {
        case 1:

            if(!Inno_flag)
                printf("InnoDB plug-in is not installed\n");
            else
                printf("InnoDB plug-in is installed\n");
                mysql_free_result(result);//Freeing the buffer 
                //To fetch Total Disk writes by MySQL 
                if(mysql_query(connection, "show global status"))
                {
                printf("\nQuery execution failed:");
                    fprintf(connection, "%s\n", mysql_error(connection));
                    exit(1);
                }

                result = mysql_use_result(connection);//fetching result 
                while((row = mysql_fetch_row(result)) != NULL)//Iterating result row
                {
                     if(strcmp(row[0], "Handler_write") == 0)
                     printf("Total number of Disk Writes by MySQL: %d\n", row[1]);
                 }
            break;
        case 2:
            if(!CSV_flag)
                                    printf("CSV support is not there.\n");
                            else
                                    printf("CSV support is there.\n");

            break;
        default:printf("\nInvalid choice\n");

    }
    mysql_free_result(result);//Freeing the buffer
        mysql_close(connection);//closing the connection 
    printf("\nDo you want to continue?(Y/N):");
    scanf("%s",&choice);
    if(choice!='Y'|| choice!='y'||choice!='n'||choice!='N')
    {
        printf("\nInvalid option. Program exits.\n");
        exit(0);
    }
    printf("\n\n\n");
}while(choice =='Y' || choice =='y' );
return 0;
    }
     //Command to run the program: gcc -o output -I/usr/include/mysql/ -lmysqlclient InnoDB_checker.c -w
0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜