一、MySQL的安装

   Mysql的安装去官网下载就可以。。。最新的是5.7版本。。

二、VC6.0的设置

(1)打开VC6.中选0 工具栏Tools菜单下的Options选项,在Directories的标签页中右边的“Show directories for:”下拉列表中“Includefiles”,然后在中间列表框中添加你本地安装MySQL的include目录路径。如图:

(2)在上面说到的“Show directories for:”下拉列表中选中“Library files”,然后添加你本地安装MySQL的Lib目录路径。如图:

 **这里要说明一下:细心的人会发现我的这个目录和上一个图中的不一样,这是因为这个错误:libmysql.lib : fatal error LNK1113: invalid machine 无效的服务器

   这是因为vc开发的是32位的程序,而mysql数据库是64位导致的,你用32位的程序去操作64位的数据库肯定会出错,我在下一篇博文中将详细说明怎么解决。

(3)在“Project settings->Link:Object/library modules”里面添加“libmysql.lib”。
        

(4)建议将“libmySQL.lib、libmySQL.dll”拷到你所建的工程的目录下。

这两个文件在D:\Mysql\lib目录下。

三、编程实现

1. 一个简单的小程序,看看是否能连接成功。。。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <stdio.h>
#include <windows.h>
#include <mysql.h>
 
int main()
{
 
       MYSQL mysql;
       mysql_init(&mysql); //初始化mysql结构
 
       if(!mysql_real_connect(&mysql,"localhost","myuser","123456","student_db",3306,NULL,0))
              printf("\n连接数据库时发生错误!\n");
       else
              printf("\n连接数据库成功!\n");
 
       mysql_close(&mysql); //释放数据库
   
       return 0;
}

  mysql_real_connect(&mysql,"localhost","myuser","123456","student_db",3306,NULL,0)//myuser是我的用户名,“123456”是密码,“student_db”是数据库,3306是端口号

2.实现查询小程序

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
// test.cpp : Defines the entry point for the console application.
//
#include <stdio.h>
#include <windows.h>
#include "StdAfx.h"
 
#include <winsock.h> 
#include <iostream> 
#include <string> 
#include <mysql.h> 
using namespace std; 
//不需要单步调试的就注释掉 
//#define STEPBYSTEP 
   
void pause(){ 
   
    #ifdef STEPBYSTEP 
        system("pause"); 
    #endif 
void writeToFile(const char *s) 
   
     FILE *fp=fopen("info.txt","rw"); 
     fprintf(fp,s); 
     fclose(fp); 
   
 /* int main()
 
{
 
       MYSQL mysql;
       mysql_init(&mysql); //初始化mysql结构
 
       if(!mysql_real_connect(&mysql,"localhost","myuser","123456","student_db",3306,NULL,0))
              printf("\n连接数据库时发生错误!\n");
       else
              printf("\n连接数据库成功!\n");
 
       mysql_close(&mysql); //释放数据库
   
       return 0;
}*/
int main(int argc, char* argv[]){ 
   
    cout<<"start...."<<endl; 
    pause(); 
    MYSQL mysql; 
    if(0==mysql_library_init(0,NULL,NULL)) 
    
        cout<<"mysql_library_init succeed"<<endl; 
   
    }else
        cout<<"mysql_library_init failed"<<endl; 
        return -1; 
    
    pause(); 
    if(NULL!=mysql_init(&mysql)) 
    
   
        cout<<"mysql_init succeed"<<endl; 
    }else
        cout<<"mysql_init failed"<<endl; 
        return -1; 
    
    pause(); 
    if(0==mysql_options(&mysql,MYSQL_SET_CHARSET_NAME,"gb2312")) 
    
   
        cout<<"mysql_option succeed"<<endl; 
    }else
        cout<<"mysql_option failed"<<endl; 
        return -1; 
    
    pause(); 
   
    if(NULL!=mysql_real_connect(&mysql,"localhost","myuser","123456","student_db",3306,NULL,0)) 
    
   
        cout<<"mysql_real_connect succeed"<<endl; 
    }else
        cout<<"mysql_real_connect failed"<<endl; 
        return -1; 
    
    pause(); 
    string sql; 
     
    sql="select * from sgroup"
    MYSQL_RES *result=NULL; 
    if(0==mysql_query(&mysql,sql.c_str())) 
    
   
            cout<<"mysql_query select succeed"<<endl; 
            result=mysql_store_result(&mysql); 
            int rowcount=mysql_num_rows(result); 
            cout<<"row count:"<<rowcount<<endl; 
            unsigned int fieldcount=mysql_num_fields(result); 
            MYSQL_FIELD *field=NULL; 
            for(unsigned int i=0;i<fieldcount;i++) 
            
   
                field=mysql_fetch_field_direct(result,i); 
                cout<<field->name<<"\t\t"
            
            cout<<endl; 
            MYSQL_ROW row=NULL; 
            row=mysql_fetch_row(result); 
            while(NULL!=row) 
            
   
                for(int i=0;i<fieldcount;i++){ 
   
                    cout<<row[i]<<"\t\t"
   
                
                cout<<endl; 
                row=mysql_fetch_row(result); 
   
            
    }else
   
            cout<<"mysql_query select data failed"<<endl; 
            mysql_close(&mysql); 
            return -1; 
    
    pause(); 
    /*sql="drop table user_info"; 
    if(0==mysql_query(&mysql,sql.c_str())) 
    
   
            cout<<"mysql_query drop table succeed"<<endl; 
    }else{ 
            cout<<"mysql_query drop table failed"<<endl; 
            mysql_close(&mysql); 
            return -1; 
   
    }  */
    mysql_free_result(result); 
    mysql_close(&mysql); 
    mysql_server_end(); 
   
   
    system("pause"); 
    return 0; 
}

  运行结果:

至此连接成功。。哈哈。。

补充:c/c++连接数据库的方式不止一种,上面介绍的是通过MySQL自身提供C语言形式的API来进行数据库连接。除此之外还可以用connector c++来进行连接。不同的连接方式在效率、稳定性方面存在差异。

参考原文传送门:https://www.cnblogs.com/jycboy/p/5170637.html

VC++6.0连接MySQL数据库(MySQL API)的更多相关文章

  1. VC++6.0连接Access数据库

    建立一个连接数据库的类: 1.头文件:ADOConn.h #import "C:\Program Files\Common Files\System\ado\msado15.dll" ...

  2. java数据库 JDBC操作MySQL数据库常用API 部门表和员工表 创建表 添加数据 查询数据

    package com.swift.department; import java.sql.Connection; import java.sql.PreparedStatement; import ...

  3. 第二百八十六节,MySQL数据库-MySQL事务操作(回滚)

    MySQL数据库-MySQL事务操作(回滚) 事务用于将某些操作的多个SQL作为原子性操作,一旦有某一个出现错误,即可回滚到原来的状态,从而保证数据库数据完整性. 举例:有这样一张表 从表里可以看出张 ...

  4. 第二百八十三节,MySQL数据库-MySQL存储过程

    MySQL数据库-MySQL存储过程 MySQL存储过程,也就是有点像MySQL函数,但是他与MySQL函数是有区别的,后面会讲到函数,所以注意区分 注意:函数与存储过程的区别 存储过程是:CREAT ...

  5. 第二百八十五节,MySQL数据库-MySQL函数

    MySQL数据库-MySQL函数 1.MySQL内置函数 SELECT执行函数,后面跟要执行的函数 CHAR_LENGTH(str)函数:返回字符串的字符长度 -- CHAR_LENGTH(str)函 ...

  6. MySQL数据库”mysql SQL Error:1146,SQLState:42S02 “解决方法

    项目在开发的时候在Mac平台下开发的,开发完了之后在LINUX环境上部署好之后,运行时MySQL数据库报错,提示为某个表不存在之类的错误信息,后来修改了MySQL的配置文件将大小写敏感去掉,问题解决. ...

  7. 第二百八十四节,MySQL数据库-MySQL触发器

    MySQL数据库-MySQL触发器 对某个表进行[增/删/改]操作的前后如果希望触发某个特定的行为时,可以使用触发器,触发器用于定制用户对表的行进行[增/删/改]前后的行为. 1.创建触发器基本语法 ...

  8. 第二百八十二节,MySQL数据库-MySQL视图

    MySQL数据库-MySQL视图 1.视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,并可以将其当作表来使用. 2.也 ...

  9. Robomongo 0.9.0 连接mongo数据库时,提示连接失败 的解决方案

    Robomongo 0.9.0 连接mongo数据库时,提示连接失败.(IP和端口号确定是对的) 基本注意点: 1.mongodb服务打开,打开时,指定端口号,默认为27017,使用默认值,则不用指定 ...

随机推荐

  1. SUN平台服务器光纤共享存储互斥失败如何恢复数据?

    服务器数据恢复故障描述: 服务器最初的设计思路为将两台SPARC SOLARIS系统通过光纤交换机共享同一存储作为CLUSTER使用,正常情况下A服务器工作,当A服务器发生故障宕机后即可将其关机然后开 ...

  2. PHP trait

    ps:由于PHP是单继承的,无法继承多个类所以可以用triat(关键字,特性)来命名达到子类继承多个父类的效果:暂且理解为类吧.class = trait <?php trait A { pub ...

  3. C# 使用 GDI+ 实现添加中心旋转(任意角度)的文字

    这篇文章是 GDI+ 总结系列的第三篇,如果对 GDI+ 的基础使用不熟悉的朋友可以先看第一篇文章<C# 使用 GDI+ 画图>. 需求 需求是要实现给图片添加任意角度旋转的文字,文字的旋 ...

  4. 基于python的统计公报关键数据爬取 update

    由于之前存在的难以辨别市本级,全市相关数据的原因,经过考虑采用 把含有关键词的字段全部提取进行人工辨别的方法 在其余部分不改变的情况下,更改test部分 def test(real_Title,rea ...

  5. vue2.0+koa2+mongodb实现注册登录

    前言 前段时间和公司一个由技术转产品的同事探讨他的职业道路,对我说了一句深以为然的话: "不要把自己禁锢在某一个领域,技术到产品的转变,首先就是思维上的转变.你一直做前端,数据的交互你只知道 ...

  6. bootstrap 菜单之手风琴效果

    自己用bootstrap搭了个项目,纯属娱乐....为了检验学习bootstrap之成果. 效果如图: 一.搭建中发现一问题,因为以前测试都是写的html页面,这次用了母版页,点击页面的之后,页面会刷 ...

  7. 转:swing 中paint与paintComponent的区别(jcomponent)

    http://blog.csdn.net/q597756870/article/details/17854247 查API文档,查得在类Jcomponent下的paint方法有以下解释:        ...

  8. python 开发之路 - 入门

    一. python 介绍 Python是著名的"龟叔"Guido van Rossum在1989年圣诞节期间,为了打发无聊的圣诞节而编写的一个编程语言.1991年 发布Python ...

  9. 关于web XSS注入问题

    对web安全方面的知识非常薄弱,这篇文章把Xss跨站攻击和sql注入的相关知识整理了下,附带公司写的一个filer. 对于防止sql注入发生,我只用过简单拼接字符串的注入及参数化查询,可以说没什么好经 ...

  10. 开源协议瞎扯淡,什么是 MIT 协议?[转]

    图片来源:http://ruby-china.org/topics/15979