//下面的代码是一个实现C++连接MYSQL
数据库的很好的例子//这里用了建表,插入,检索,删表等常用功能//我用VC++6.0生成,已经成功连接了。//在VC++6.0中要想把做一下两步准备工作才可以。//(1)Tools->Options->Directories->Include files中添加C:\Program Files\MySQL\MySQL Server 6.0\include//(2)Tools->Options->Directories->Library files中添加C:\Program Files\MySQL\MySQL Server 6.0\lib\opt//其实就是将头文件和库文件包含进来//我觉得这个例子写的很好,再结合自己的试验,特地介绍给大家! #include <winsock.h>#include <iostream>#include <string>#include <mysql.h>using namespace std#pragma comment(lib, "ws2_32.lib")#pragma comment(lib, "libmysql.lib") //单步执行,不想单步执行就注释掉#define STEPBYSTEP int main() {cout <<"****************************************" <<endl#ifdef STEPBYSTEPsystem("pause")#endif //必备的一个数据结构MYSQL mydata//初始化数据库if (0 == mysql_library_init(0, NULL, NULL)) {cout <<"mysql_library_init() succeed" <<endl } else {cout <<"mysql_library_init() failed" <<endl return -1 } #ifdef STEPBYSTEPsystem("pause")#endif //初始化数据结构if (NULL != mysql_init(&mydata)) {cout <<"mysql_init() succeed" <<endl } else {cout <<"mysql_init() failed" <<endl return -1 } #ifdef STEPBYSTEPsystem("pause")#endif //在连接数据库之前,设置额外的连接选项//可以设置的选项很多,这里设置字符集,否则无法处理中文if (0 == mysql_options(&mydata, MYSQL_SET_CHARSET_NAME, "gbk")) {cout <<"mysql_options() succeed" <<endl } else {cout <<"mysql_options() failed" <<endl return -1 } #ifdef STEPBYSTEPsystem("pause")#endif //连接数据库if (NULL!= mysql_real_connect(&mydata, "localhost", "root", "test", "test",3306, NULL, 0))//这里的地址,用户名,密码,端口可以根据自己本地的情况更改{cout <<"mysql_real_connect() succeed" <<endl } else {cout <<"mysql_real_connect() failed" <<endl return -1 } #ifdef STEPBYSTEPsystem("pause")#endif //sql字符串string sqlstr//创建一个表sqlstr = "CREATE TABLE IF NOT EXISTS user_info" sqlstr += "(" sqlstr +="user_id INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY COMMENT 'Unique User ID'," sqlstr +="user_name VARCHAR(100) CHARACTER SET gb2312 COLLATE gb2312_chinese_ci NULL COMMENT 'Name Of User'," sqlstr +="user_second_sum INT UNSIGNED NOT NULL DEFAULT 0 COMMENT 'The Summation Of Using Time'" sqlstr += ")" if (0 == mysql_query(&mydata, sqlstr.c_str())) {cout <<"mysql_query() create table succeed" <<endl } else {cout <<"mysql_query() create table failed" <<endl mysql_close(&mydata) return -1 } #ifdef STEPBYSTEPsystem("pause")#endif //向表中插入数据sqlstr ="INSERT INTO user_info(user_name) VALUES('公司名称'),('一级部门'),('二级部门'),('开发小组'),('姓名')" if (0 == mysql_query(&mydata, sqlstr.c_str())) {cout <<"mysql_query() insert data succeed" <<endl } else {cout <<"mysql_query() insert data failed" <<endl mysql_close(&mydata) return -1 } #ifdef STEPBYSTEPsystem("pause")#endif //显示刚才插入的数据sqlstr = "SELECT user_id,user_name,user_second_sum FROM user_info" MYSQL_RES *result = NULL if (0 == mysql_query(&mydata, sqlstr.c_str())) {cout <<"mysql_query() select data succeed" <<endl//一次性取得数据集result = mysql_store_result(&mydata) //取得并打印行数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 = 0i <fieldcounti++) {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 = 0i <fieldcounti++) {cout <<row[i] <<"\t\t" }cout <<endl row = mysql_fetch_row(result) } } else {cout <<"mysql_query() select data failed" <<endl mysql_close(&mydata) return -1 } #ifdef STEPBYSTEPsystem("pause")#endif //删除刚才建的表sqlstr = "DROP TABLE user_info" if (0 == mysql_query(&mydata, sqlstr.c_str())) {cout <<"mysql_query() drop table succeed" <<endl } else {cout <<"mysql_query() drop table failed" <<endl mysql_close(&mydata) return -1 }mysql_free_result(result) mysql_close(&mydata) mysql_server_end()system("pause") return 0}通过VC开发MySQL数据库应用软件有多种方式:
一、通过MyODBC界面
二、通过Connector/C++l界面
三、通过MySQL C API界面
四、第三方封装的MySQL类
在VC中使用MySQL的步骤如下:
1、下载MySQL的服务器/客户端安装包
官方下载地址如下:
http://www.mysql.com/downloads/mysql-4.0.html
MySQL for Windows V4.0.12
2、安装MySQL服务器/客户端包
一般情况,选择下一步就行了。
默认情况,MySQL会安装到C:\mysql下。
3、在VC中设置其开发环境
a.设置包含路径为c:\mysql\include
b.设置引用路径为c:\mysql\include
c.设置库路径为c:\mysql\lib\debug
d.设置链接器-输入-附加依赖项为libmySQL.lib
e.在stdafx.h中加入以下行:
#include <winsock.h>
#include "mysql.h "
4、至此就可以使用C API函数进行开发了。
MySQL提供了很多函数来对数据库进行 *** 作,大致可以分为以下几类:
第一部分 控制类函数
mysql_init()初始化MySQL对象
mysql_options()设置连接选项
mysql_real_connect()连接到MySQL数据库
mysql_real_escape_string()将查询串合法化
mysql_query()发出一个以空字符结束的查询串
mysql_real_query()发出一个查询串
mysql_store_result()一次性传送结果
mysql_use_result()逐行传送结果
mysql_free_result()释放结果集
mysql_change_user()改变用户
mysql_select_db()改变默认数据库
mysql_debug()送出调试信息
mysql_dump_debug_info()转储调试信息
mysql_ping()测试数据库是否处于活动状态
mysql_shutdown()请求数据库SHUTDOWN
mysql_close()关闭数据库连接
第二部分 信息获取类函数
mysql_character_set_name()获取默认字符集
mysql_get_client_info()获取客户端信息
mysql_host_info()获取主机信息
mysql_get_proto_info()获取协议信息
mysql_get_server_info()获取服务器信息
mysql_info()获取部分查询语句的附加信息
mysql_stat()获取数据库状态
mysql_list_dbs()获取数据库列表
mysql_list_tables()获取数据表列表
mysql_list_fields()获取字段列表
第三部分 行列类 *** 作函数
mysql_field_count()获取字段数
mysql_affected_rows()获取受影响的行数
mysql_insert_id()获取AUTO_INCREMENT列的ID值
mysql_num_fields()获取结果集中的字段数
mysql_field_tell()获取当前字段位置
mysql_field_seek()定位字段
mysql_fetch_field()获取当前字段
mysql_fetch_field_direct()获取指定字段
mysql_frtch_fields()获取所有字段的数组
mysql_num_rows()获取行数
mysql_fetch_lengths()获取行长度
mysql_row_tell()获取当前行位置
mysql_row_seek()行定位
mysql_data_seek()行定位
mysql_fetch_row()获取当前行
第四部分 线程类 *** 作函数
mysql_list_processes()返回所有线程列表
mysql_thread_id()获取当前线程ID
mysql_thread_safe()是否支持线程方式
mysql_kill()杀列一个线程
第五部分 出错处理类函数
mysql_errno()获取错误号
mysql_error()获取错误信息
第六部分 已过时的函数
mysql_connect()
mysql_create_db()
mysql_drop_db()
mysql_eof()
mysql_reload()
mysql_escape_string()
用ADO连接SQL数据库
步骤如下:
1,在头文件"StdAfx.h"中导入#import "C:/Program Files/Common Files/System/ado/msado15.dll" no_namespace rename("EOF","rsEOF"),记住把这句话放到endif的后面,不然会报错,这样处理好之后,编译后又一个警告,可以忽略
2,在对话框的OnInitDialog()函数中写上"::CoInitialize(NULL)::AfxOleInit()” 在主程序的初始化函数中,它就可以写一次
3,在对话框类的头文件中,声明如下变量:_ConnectionPtr m_pConnection_RecordsetPtr pRst
连接数据库的代码如下:
try
{
hr=m_pConnection.CreateInstance("ADODB.Connection")
if(SUCCEEDED(hr))
{
hr=m_pConnection->Open("Provider=数据库的驱动器名称Integrated Security=SSPIPersist Security Info=FalseData Source=数据库服务器名Initial Catalog=连接的数据库名User ID=登陆数据库的名称Password=登陆数据库的密码","","",adModeUnknown)
}
}
catch(_com_error e)
{
AfxMessageBox(e.ErrorMessage())
}
”数据库的驱动器名称“在控制面板里,以大图标查看,可以看到一个"ODBC",双击打开,在”驱动程序“里面在最下面有两个”SQL Server"和“SQL Native Client"如果你是2000的SQL版本,就选”SQL Server"及“Provider=SQL Server"2005的"Provider=SQL Native Client"Data Source=? ,?的值可以是”localhost"也可以是你的数据库服务器的名称,连接数据库的时候可以看到,复制一下就可以了。
处理完之后就可以连接到你想要连接的数据库上了!你下次给点分把!!!
评论列表(0条)