一、在VC中可以按照如下方法实现与MySQL数据库的连接

第一步:完全安装MySQL;

VC的MySQL编程 - myswirl - MY BLOG

              完全安装后,会在安装目录看到如下目录:
VC的MySQL编程 - myswirl - MY BLOG
 

第二步:找来MySQL(Win32)安装目录下的include文件夹,将其添加到VC头文件目录列表中;

(VC6 -> Tools->Options -> Directories -> 加入此目录)

VC的MySQL编程 - myswirl - MY BLOG

 

第三步:找来MySQL(Win32)安装目录下的lib文件夹,将 其添加到VC库文件目录列表中;

(VC6 ->Tools-> Options -> Directories -> 加入此目录)

VC的MySQL编程 - myswirl - MY BLOG

 

二、MySQL测试例子,新建一个"Win32 Console Application"工程,参考如下代码:

*************************************mysqltest.cpp***************************************

#include <stdio.h>
#include <winsock.h>
#include <mysql.h>
#include <windows.h>
#pragma comment(lib, "libmysql.lib")

int main(int argc, char* argv[])
{
    unsigned short Port = 3306;
    char *IPAddress = "192.168.10.147";
    char *UserName = "root";
    char *Password = "djtest";
    char *DBName = "activeCode";
    unsigned long i;
    printf("Start... \n");
    
    MYSQL *ssock;
    MYSQL_RES   *res;      
    MYSQL_ROW   row;   
    //char execsql[500];
    ssock = (MYSQL *)malloc(sizeof(MYSQL));  
    //在某些版本中,不需要该初始化工作,可观看mysql.H以及readme
    mysql_init(ssock);
    if(ssock == NULL)
    {
        printf("EROR: MySQL ssock init error. \n");
        return FALSE;
    }
    printf("MySQL ssock init OK. \n");
    
    //连接到指定的数据库
    ssock = mysql_real_connect(ssock, IPAddress, UserName, Password, NULL, Port, NULL, 0);
    if(!ssock)
    {
        printf("conn fail... \n");
        //memcpy(eee, mysql_error(ssock), 20);
        //fprintf(stderr, "Failed to connect to database: Error: %s ", mysql_error(ssock));
        
        //printf("%c ", eee);

        unsigned int mtint = mysql_errno(ssock);
        //printf("%d ");
        return FALSE;
    }
    printf("MySQL connnect OK... \n");
    
    if(mysql_select_db(ssock, DBName) != 0)
    {
        printf("select db error. \n");
        return FALSE;
    }
    printf("select db OK. \n");
    printf("version=%d \n", mysql_get_server_version(ssock));
    //SQL查询语句
    if(mysql_query( ssock,"SELECT * FROM  userinfodf"))  
    {
        printf("mysql_query() Error, %s\n", mysql_error(ssock));  
    }
    
    if( !(res = mysql_store_result(ssock)) )  
    {
        printf("mysql_store_result() Error, %s\n", mysql_error(ssock));  
    } 
    
    while( (row = mysql_fetch_row(res)) )
    {          
        for(i=0 ; i<mysql_num_fields(res); i++)  
        {
            printf("%s ",row[i]);
        }    
        printf("\n");
    }      
    mysql_free_result(res);   
    //执行SQL插入语句,第一列自增
    
if(mysql_query( ssock,"insert into UserInfo SET userName=\'lmy4\', userLogName=\'lmy4\', userLogPWD=\'000000\', userRole=1,userState=0 " ))  
    {
        printf("mysql_query() Error, %s\n", mysql_error(ssock));  
    }

    mysql_close(ssock);
    printf("End... \n");
    
    return TRUE;
}

 

****************************************************************************************

运行效果图:

VC的MySQL编程 - myswirl - MY BLOG
 

 

三、VC中操作MySQL数据库函数详解

执行一个查询有以下几个步骤要做。

首先执行一个查询,然后保存结果,  得到的是一个子集。这里是一个小例子:  

       mysql_query函数:将把查询送给服务器,如果查询成功,调用mysql_store_result 函数将分配一个MYSQL_RES 结构并且重新从服务器获得一个结果集。

mysql_fetch_row函数:来查看数据。这样做你将获得一个 MYSQL_ROW 指针指向数据中的一行。MYSQL_ROW 指针是一简单的字符串数组。所有的数据类型被转换成字符串送到客户端。  

mysql_num_fields函数:将告诉你返回的列数。你可以继续调用mysql_fetch_row直到它返回一个空指针以得到查询中的每一行。  

注意:在这个例子里,我们没有检查有空指针的列。如果你不使用非空列的表,那么你必须检查一个特殊行的列是否为空。一旦你使用完毕一个结果集,你必须释放它。这通过 mysql_free_result 来完成。  

最后调用mysql_close来关闭你和数据库之间的连接。  

查看结果集你可以不用调用mysql_fetch_row就查出返回的结果集共有多少行。这由int   mysql_num_rows(MYSQL_RES   *result)来完成。  

改变到被下一个 mysql_fetch_row 调用返回的行,你可以用void mysql_data_seek(MYSQL_RES   *res,   uint   offset) 改变到任意一行。 获得更多的信息你可以使用这几个额外的函数来找出关于一个查询的更多的信息,并从服务器获得这些信息。  

如果你执行一个UPDATE,INSERT 或者 DELETE 查询,你可以用int mysql_affected_rows 来查出共有多少行数据被你影响到。  

如果在你的数据库里有二进制数据,那么得知数据的长度将是有用的。unsigned   int   *mysql_fetch_lengths(MYSQL_RES   *mysql)   将返回一指出了结果集中每一列 的长度的整型数组。  

当你插入一个带有   AUTO_INCREMENT   列的表的时候,你可以用int   mysql_insert_id(MYSQL   *mysql)   来查出生成的那一行的ID。  

posted on 2011-12-07 10:57  无语东流  阅读(440)  评论(0)    收藏  举报