C++连接mysql数据库的两种方法_第1页
C++连接mysql数据库的两种方法_第2页
C++连接mysql数据库的两种方法_第3页
C++连接mysql数据库的两种方法_第4页
C++连接mysql数据库的两种方法_第5页
已阅读5页,还剩8页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、C+连接mysql数据库的两种方法现在正做一个接口,通过不同的连接字符串操作不同的数据库。要用到mysql数据库,以前没用过这个数据库,用access和sql server比较多。通过网上的一些资料和自己的摸索,大致清楚了C+连接mysql的方法。可以通过2种方法实现。第一种方法是利用ADO连接,第二种方法是利用mysql自己的api函数进行连接。第一种方法可以实现我当前的需求,通过连接不同的字符串来连接不同的数据库。暂时只连接了mysql,sqlserver,oracle,access。对于access,因为它创建表的SQL语句不太兼容标准SQL语句,需要做一些处理,这里暂时不说。第二种方法

2、只能针对于mysql数据库的连接,不过用这种方法不用安装MyODBC服务器程序。不管用哪种方法,首先需要安装Mysql数据库,安装方法请看“mysql安装及一些注意点”。最好安装一个Navicat for mysql,方便操作mysql数据库。下面分别说下这两种方法:(一)通过ADO连接MySql数据库1、通过ADO连接MySql数据库,首先得安装MyODBC服务器程序。MyODBC版本要和MySql的版本对应上,否则会连接不上数据库。我用的版本分别是mysql-5.1.48-win32.msi和mysql-connector-odbc-5.1.5-win32.msi。安装好后,点击开始菜单&

3、gt;设置>控制面板>管理工具>数据源(ODBC)>用户DSN>添加>选择MySQL ODBC 5.1 Driver。如下图:然后双击MySQL ODBC 5.1 Driver进行配置。配置好可以点Test进行下测试(如下图),如果能连上会弹出connection successful对话框。上图中的Data Source Name:中的内容就是代码里DSN所对应的值。例如:"DSN=MySqlODBC;server=localhost;database=test"。2、配置好后,就可以开始编码了。(1)首先导入ADO类型库。#impor

4、t "c:program filescommon filessystemadomsado15.dll" no_namespace rename("EOF","adoEOF")。您的环境中msado15.dll不一定在这个目录下,请按实际情况修改。或者把msado15.dll这个文件拷贝到你的工程目录下,直接#import "msado15.dll" no_namespace rename ("EOF", "adoEOF")包含进来。(2 )创建Connection对象并连接数

5、据库1.    2. CoInitialize(NULL);   3. m_pConnection.CreateInstance(_uuidof(Connection);   4. try 5.  6. /设置连接时间  7. m_pConnection->ConnectionTimeout = 5;  8. /打开数据库连接  9. HRESULT hr = m_pConnection->Open("DSN=My

6、SqlODBC;server=localhost;database=test","root","root",adModeUnknown);  10.  11. catch(_com_error &e)  12.  13. MessageBox(NULL, e.Description(), _T(""), MB_OK);  14. return FALSE;  15.    16. retu

7、rn TRUE;  17.   (3)执行SQL语句1. BOOL CDBManagerSub:ExecuteSQL( _bstr_t bstrSQL )  2.  3. / _variant_t RecordsAffected;  4. try 5.  6. / 是否已经连接数据库  7. if(m_pConnection = NULL)  8.  9. /重新连接数据库  

8、10. Open(m_dbType, m_strServer, m_strUserName, m_strPasswor, m_strDBName);  11.  12. / Connection对象的Execute方法:(_bstr_t CommandText,   13. / VARIANT * RecordsAffected, long Options )   14. / 其中CommandText是命

9、令字串,通常是SQL命令。  15. / 参数RecordsAffected是操作完成后所影响的行数,   16. / 参数Options表示CommandText的类型:adCmdText-文本命令;adCmdTable-表名  17. / adCmdProc-存储过程;adCmdUnknown-未知  18. _RecordsetPtr hr = m_pConnection->Execute(bstrSQL,NULL,adCmdText);  19. return&

10、#160;true;  20.  21. catch(_com_error e)  22.  23. MessageBox(NULL, e.Description(), _T(""), MB_OK);  24. return false;  25.  26.   _bstr_t bstrSQL为输入的SQL语句,如果返回TRUE,则执行成功,返回FLASH则会报对应的错误提示。例如:下面的创建testTable表的SQL语句:1. ch

11、ar* pQuery = "create table if not exists testTable( ID VARCHAR(10), Name VARCHAR(255),Descs VARCHA(255),PRIMARY KEY (ID)"  2. ExecuteSQL(pQuery);   3、附上mysql数据库的操作,方便没有安装Navicat for mysql的朋友参考。 打

12、开“开始->所有程序->MySQL->MySQL Server 5.0->MySQL Command Line Client.exe”,如果没有设置密码就直接按回车,会提示服务器启动成功。1. mysql> SHOW DATABASES;/显示所有的数据库,注意一定要 敲“;”后再按回车  2. mysql> CREATE DATABASE mydb;/创建数据库  3. mydbmysql> USE mydb;/选择你所创建的数据库  4.

13、mydbmysql> SHOW TABLES; /显示数据库中的表  5. mysql> CREATE TABLE mytable (username VARCHAR(100), visitelist VARCHAR(200),remark VARCHAR(200),PRIMARY KEY (username);/创建一个表mytable: 用户名;访问列表,主键为username  6. mysql> DE

14、SCRIBE mytable;/显示表的结构(二)通过MySQL自己的API函数进行连接1、使用API的方式连接,需要加载mysql的头文件和lib文件。在VS2010的附加包含目录中添加MySQLMySQL Server 5.1include。在安装MySql的目录下找。 把libmysql.dll和libmysql.lib文件拷贝到所建的工程目录下。然后在头文件里包含以下内容:1. /mysql所需的头文件和库文件  2. #include "winsock.h" 3. #include "mysql.h&qu

15、ot; 4. #pragma comment(lib,"libmySQL.lib") 2、进行编码(1)连接mysql数据库头文件里定义数据源指针 MYSQL m_sqlCon;/连接MySql数据库1. try 2.  3. mysql_init(&m_sqlCon);  4. / localhost:服务器 root为账号密码 test为数据库名 3306为端口  5. if(!mysql_real_connect(&m_sqlCon, 

16、;"localhost","root","root","test",3306,NULL,0)  6.  7. AfxMessageBox(_T("数据库连接失败!");  8. return FALSE;  9.    10. return TRUE;  11.  12. catch (.)  13.  14. return FALSE;  15.

17、  (2)关闭数据库1. mysql_close(&m_sqlCon); (3)创建表1. char* pQuery = "create table if not exists DS_Building( ID VARCHAR(10),Name VARCHAR(255),Descs VARCHAR(255),PRIMARY KEY (ID)"   2. if(mysql_real_query

18、(&m_sqlCon,pQuery,(UINT)strlen(pQuery)!=0)  3.    4. const char* pCh = mysql_error(&m_sqlCon);  5. return FALSE;  6.  附MySQL的API接口:1. mysql_affected_rows() 返回被最新的UPDATE, DELETE或INSERT查询影响的行数。  2. mysql_close() 关闭一个服务器

19、连接。  3. mysql_connect() 连接一个MySQL服务器。该函数不推荐;使用mysql_real_connect()代替。  4. mysql_change_user() 改变在一个打开的连接上的用户和数据库。  5. mysql_create_db() 创建一个数据库。该函数不推荐;而使用SQL命令CREATE DATABASE。  6. mysql_data_seek() 在一个查询结果集合中搜寻一任意行。  7. mysql_debug() 用给定字符串做一个DB

20、UG_PUSH。  8. mysql_drop_db() 抛弃一个数据库。该函数不推荐;而使用SQL命令DROP DATABASE。  9. mysql_dump_debug_info() 让服务器将调试信息写入日志文件。  10. mysql_eof() 确定是否已经读到一个结果集合的最后一行。这功能被反对; mysql_errno()或mysql_error()可以相反被使用。  11. mysql_errno() 返回最近被调用的MySQL函数的出错编号。  12. mysql_

21、error() 返回最近被调用的MySQL函数的出错消息。  13. mysql_escape_string() 用在SQL语句中的字符串的转义特殊字符。  14. mysql_fetch_field() 返回下一个表字段的类型。  15. mysql_fetch_field_direct () 返回一个表字段的类型,给出一个字段编号。  16. mysql_fetch_fields() 返回一个所有字段结构的数组。  17. mysql_fetch_lengths() 返回

22、当前行中所有列的长度。  18. mysql_fetch_row() 从结果集合中取得下一行。  19. mysql_field_seek() 把列光标放在一个指定的列上。  20. mysql_field_count() 返回最近查询的结果列的数量。  21. mysql_field_tell() 返回用于最后一个mysql_fetch_field()的字段光标的位置。  22. mysql_free_result() 释放一个结果集合使用的内存。  23. mysql_get_cl

23、ient_info() 返回客户版本信息。  24. mysql_get_host_info() 返回一个描述连接的字符串。  25. mysql_get_proto_info() 返回连接使用的协议版本。  26. mysql_get_server_info() 返回服务器版本号。  27. mysql_info() 返回关于最近执行得查询的信息。  28. mysql_init() 获得或初始化一个MYSQL结构。  29. mysql_insert_id() 

24、返回有前一个查询为一个AUTO_INCREMENT列生成的ID。  30. mysql_kill() 杀死一个给定的线程。  31. mysql_list_dbs() 返回匹配一个简单的正则表达式的数据库名。  32. mysql_list_fields() 返回匹配一个简单的正则表达式的列名。  33. mysql_list_processes() 返回当前服务器线程的一张表。  34. mysql_list_tables() 返回匹配一个简单的正则表达式的表名。  35. mysq

25、l_num_fields() 返回一个结果集合重的列的数量。  36. mysql_num_rows() 返回一个结果集合中的行的数量。  37. mysql_options() 设置对mysql_connect()的连接选项。  38. mysql_ping() 检查对服务器的连接是否正在工作,必要时重新连接。  39. mysql_query() 执行指定为一个空结尾的字符串的SQL查询。  40. mysql_real_connect() 连接一个MySQL服务器。  

26、41. mysql_real_query() 执行指定为带计数的字符串的SQL查询。  42. mysql_reload() 告诉服务器重装授权表。  43. mysql_row_seek() 搜索在结果集合中的行,使用从mysql_row_tell()返回的值。  44. mysql_row_tell() 返回行光标位置。  45. mysql_select_db() 连接一个数据库。  46. mysql_shutdown() 关掉数据库服务器。  47. mysql_s

27、tat() 返回作为字符串的服务器状态。  48. mysql_store_result() 检索一个完整的结果集合给客户。  49. mysql_thread_id() 返回当前线程的ID。  50. mysql_use_result() 初始化一个一行一行地结果集合的检索。memset原型:extern void *memset(void *buffer, int c, int count);用法:i nclude功能:把buffer所指内存区域的前count个字节设置成字符c。说明:返回指向buffer的指针。 1:

28、#include <windows.h> 2: #include "stdio.h" 3: #include "winsock.h" 4: #include "mysql.h" 5:   6:   7: int main() 8: 9:   10: MYSQL * con; /= mysql_init(MYSQL*) 0); 11: MYSQL_RES *res; 12: MYSQL_ROW row; 13:   14:   15: char tmp400; 16: 

29、60; 17: /database configuartion 18: char dbuser30="root" 19: char dbpasswd30="apple" 20: char dbip30="localhost" 21: char dbname50="excel" 22: char tablename50="test" 23: char *query=NULL; 24:   25:   26: int x; 27: int y; 28: int rt;/retur

30、n value 29: unsigned int t; 30:   31: int count = 0; 32:   33:   34: printf("input x,yn"); 35: scanf("%d,%d",&x,&y); 36: fflush(stdin); 37: printf("input overn"); 38: con = mysql_init(MYSQL*) 0); 39:   40:   41: if ( con !=NULL &&

31、; mysql_real_connect(con,dbip,dbuser,dbpasswd,dbname,3306/*TCP IP端口*/,NULL/*Unix Socket 连接类型*/,0/*运行成ODBC数据库标志*/) ) 42: 43: if (!mysql_select_db(con,dbname) 44: 45: printf("Select successfully the database!n"); 46: 47: con ->reconnect = 1; 48:   49: query = "set names 'GBK

32、'" 50: /mysql_query(con,"set names 'GBK'"); 51: 52: rt=mysql_real_query(con,query,strlen(query); 53: if (rt) 54: 55: printf("Error making query: %s !n",mysql_error(con); 56: 57: else 58: 59: printf("query %s succeed!n",query); 60: 61: 62: 63: 64:  

33、 65: else 66: 67: MessageBoxA(NULL,"Unable to connect the database,check your configuration!","",NULL); 68:   69: 70:   71: /sprintf(tmp,"update %s set 商品='%s',卖出=%d,成交=%d,涨跌=%d,买进=%d,总量=%d,涨幅=%f,时间='%s' where %s",tablename,goods,sold,deal,fluc

34、tuate,buy,total,delta,time,UpdateCon); 72: sprintf(tmp,"insert into %s values(%s,%d,%d)",tablename,"null",x,y); /注意如何向具有自增字段的数据库中插入记录 73: /MessageBoxA(NULL,tmp,tmp,MB_OK); 74: /mysql_query(con,tmp); 75:   76: rt=mysql_real_query(con,tmp,strlen(tmp); 77: if (rt) 78: 79: print

35、f("Error making query: %s !n",mysql_error(con); 80: 81: else 82: 83: printf("%s executed!n",tmp); 84: 85: 86: sprintf(tmp,"select * from %s",tablename); 87: 88: rt=mysql_real_query(con,tmp,strlen(tmp); 89: if (rt) 90: 91: printf("Error making query: %s !n",mys

36、ql_error(con); 92: 93: else 94: 95: printf("%s executed!n",tmp); 96: 97: 98: res = mysql_store_result(con);/将结果保存在res结构体中 99:   100: while(row = mysql_fetch_row(res) 101: 102: /* 103: * MYSQL_ROW STDCALL mysql_fetch_row(MYSQL_RES *result); 104: * 检索行 105: */ 106:   107: for(t=0;t

37、<mysql_num_fields(res);t+) 108: 109: printf("%s ",rowt); 110: 111: printf(".n"); 112: count +; 113: 114: printf("number of rows %dn",count); 115: printf("mysql_free_result.n"); 116: mysql_free_result(res); 117:   118: mysql_close(con); 119: return 0; 1

38、20:   121: (一)通过ADO连接MySql数据库    1、通过ADO连接MySql数据库,首先得安装MyODBC服务器程序。MyODBC版本要和MySql的版本对应上,否则会连接不上数据库。我用的版本分别是mysql-5.1.48-win32.msi和mysql-connector-odbc-5.1.5-win32.msi。    安装好后,点击开始菜单>设置>控制面板>管理工具>数据源(ODBC)>用户DSN>添加>选择MySQL ODBC 5.1 Driver。如下图

39、:         然后双击MySQL ODBC 5.1 Driver进行配置。配置好可以点Test进行下测试(如下图),如果能连上会弹出connection successful对话框。         上图中的Data Source Name:中的内容就是代码里DSN所对应的值。例如:"DSN=MySqlODBC;server=localhost;database=test"。    2、配置好后,就可以开始编码了。 (1

40、)首先导入ADO类型库。#import "c:program filescommon filessystemadomsado15.dll" no_namespace rename("EOF","adoEOF")。您的环境中msado15.dll不一定在这个目录下,请按实际情况修改。或者把msado15.dll这个文件拷贝到你的工程目录下,直接#import "msado15.dll" no_namespace rename ("EOF", "adoEOF")包含进来。

41、0;(2   创建Connection对象并连接数据库                  CoInitialize(NULL);         m_pConnection.CreateInstance(_uuidof(Connection);         try 

42、                       /设置连接时间                m_pConnection->ConnectionTimeout = 5;     

43、0;          /打开数据库连接                HRESULT hr = m_pConnection->Open("DSN=MySqlODBC;server=localhost;database=test","root","root",adModeUnknown);&#

44、160;               catch(_com_error &e)                        MessageBox(NULL, e.Description(), _T(""), MB_OK)

45、;                return FALSE;                return TRUE;      (3)执行SQL语句    BOOL CDBManagerSub:ExecuteSQL( _bstr_t bst

46、rSQL )           /    _variant_t RecordsAffected;        try                        / 是否已经连接数据库

47、                if(m_pConnection = NULL)                               

48、0;        /重新连接数据库                        Open(m_dbType, m_strServer, m_strUserName, m_strPasswor, m_strDBName);      &#

49、160;                         / Connection对象的Execute方法:(_bstr_t CommandText,                 / VARIANT * Record

50、sAffected, long Options )                 / 其中CommandText是命令字串,通常是SQL命令。                / 参数RecordsAffected是操作完成后所影响的行数,      

51、;           / 参数Options表示CommandText的类型:adCmdText-文本命令;adCmdTable-表名                / adCmdProc-存储过程;adCmdUnknown-未知          

52、;      _RecordsetPtr hr = m_pConnection->Execute(bstrSQL,NULL,adCmdText);                return true;                catch(_com

53、_error e)                        MessageBox(NULL, e.Description(), _T(""), MB_OK);                return

54、false;                _bstr_t bstrSQL为输入的SQL语句,如果返回TRUE,则执行成功,返回FLASH则会报对应的错误提示。      例如下面的创建testTable表的SQL语句:      char* pQuery = "create table if not exists testTable( ID VARCHAR(10), Name VARCHAR(255),Descs VARCHAR(255),PRIMARY KEY (ID)"      ExecuteSQL(pQuery);     3、附上mysql数据库的操作,方便没有安装Navicat for mysql的朋友参考。       打开“开始->所有程序->MySQL->MySQL Server 5.0->MySQL

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论