2022-10-27 403
在上一篇文章《用C++连接MySQL等数据库一》中,笔者介绍了C++连接MySQL等数据库的***种方法——通过ADO连接MySQL数据库,这种方法通过连接不同的字符串来连接不同的数据库。在这篇文中里,笔者继续介绍连接的第二种方法。
(二)通过MySQL自己的API函数进行连接
1、使用API的方式连接,需要加载mysql的头文件和lib文件。在VS2010的附加包含目录中添加\MySQL\MySQL Server 5.1\include。在安装MySql的目录下找。 把libmysql.dll和libmysql.lib文件拷贝到所建的工程目录下。然后在头文件里包含以下内容 //mysql所需的头文件和库文件
#include"winsock.h" #include"mysql.h" #pragmacomment(lib,"libmySQL.lib")
2、进行编码
(1)连接mysql数据库
头文件里定义数据源指针 MYSQL m_sqlCon;
//连接MySql数据库 try { mysql_init(&m_sqlCon); //localhost:服务器root为账号密码test为数据库名3306为端口 if(!mysql_real_connect(&m_sqlCon,"localhost","root","root","test",3306,NULL,0)) { AfxMessageBox(_T("数据库连接失败!")); returnFALSE; } returnTRUE; } catch(...) { returnFALSE; }
(2)关闭数据库
mysql_close(&m_sqlCon);
(3)创建表
char*pQuery="createtableifnotexistsDS_Building(IDVARCHAR(10),NameVARCHAR(255),DescsVARCHAR(255),PRIMARYKEY(ID))" if(mysql_real_query(&m_sqlCon,pQuery,(UINT)strlen(pQuery))!=0) { constchar*pCh=mysql_error(&m_sqlCon); returnFALSE; }
附MySQL的API接口
mysql_affected_rows()返回被***的UPDATE,DELETE或INSERT查询影响的行数。 mysql_close()关闭一个服务器连接。 mysql_connect()连接一个MySQL服务器。该函数不推荐;使用mysql_real_connect()代替。 mysql_change_user()改变在一个打开的连接上的用户和数据库。 mysql_create_db()创建一个数据库。该函数不推荐;而使用SQL命令CREATEDATABASE。 mysql_data_seek()在一个查询结果集合中搜寻一任意行。 mysql_debug()用给定字符串做一个DBUG_PUSH。 mysql_drop_db()抛弃一个数据库。该函数不推荐;而使用SQL命令DROPDATABASE。 mysql_dump_debug_info()让服务器将调试信息写入日志文件。 mysql_eof()确定是否已经读到一个结果集合的***一行。这功能被反对;mysql_errno()或mysql_error()可以相反被使用。 mysql_errno()返回最近被调用的MySQL函数的出错编号。 mysql_error()返回最近被调用的MySQL函数的出错消息。 mysql_escape_string()用在SQL语句中的字符串的转义特殊字符。 mysql_fetch_field()返回下一个表字段的类型。 mysql_fetch_field_direct()返回一个表字段的类型,给出一个字段编号。 mysql_fetch_fields()返回一个所有字段结构的数组。 mysql_fetch_lengths()返回当前行中所有列的长度。 mysql_fetch_row()从结果集合中取得下一行。 mysql_field_seek()把列光标放在一个指定的列上。 mysql_field_count()返回最近查询的结果列的数量。 mysql_field_tell()返回用于***一个mysql_fetch_field()的字段光标的位置。 mysql_free_result()释放一个结果集合使用的内存。 mysql_get_client_info()返回客户版本信息。 mysql_get_host_info()返回一个描述连接的字符串。 mysql_get_proto_info()返回连接使用的协议版本。 mysql_get_server_info()返回服务器版本号。 mysql_info()返回关于最近执行得查询的信息。 mysql_init()获得或初始化一个MYSQL结构。 mysql_insert_id()返回有前一个查询为一个AUTO_INCREMENT列生成的ID。 mysql_kill()杀死一个给定的线程。 mysql_list_dbs()返回匹配一个简单的正则表达式的数据库名。 mysql_list_fields()返回匹配一个简单的正则表达式的列名。 mysql_list_processes()返回当前服务器线程的一张表。 mysql_list_tables()返回匹配一个简单的正则表达式的表名。 mysql_num_fields()返回一个结果集合重的列的数量。 mysql_num_rows()返回一个结果集合中的行的数量。 mysql_options()设置对mysql_connect()的连接选项。 mysql_ping()检查对服务器的连接是否正在工作,必要时重新连接。 mysql_query()执行指定为一个空结尾的字符串的SQL查询。 mysql_real_connect()连接一个MySQL服务器。 mysql_real_query()执行指定为带计数的字符串的SQL查询。 mysql_reload()告诉服务器重装授权表。 mysql_row_seek()搜索在结果集合中的行,使用从mysql_row_tell()返回的值。 mysql_row_tell()返回行光标位置。 mysql_select_db()连接一个数据库。 mysql_shutdown()关掉数据库服务器。 mysql_stat()返回作为字符串的服务器状态。 mysql_store_result()检索一个完整的结果集合给客户。 mysql_thread_id()返回当前线程的ID。 mysql_use_result()初始化一个一行一行地结果集合的检索。
原文链接:https://77isp.com/post/4263.html
=========================================
https://77isp.com/ 为 “云服务器技术网” 唯一官方服务平台,请勿相信其他任何渠道。
数据库技术 2022-03-28
网站技术 2022-11-26
网站技术 2023-01-07
网站技术 2022-11-17
Windows相关 2022-02-23
网站技术 2023-01-14
Windows相关 2022-02-16
Windows相关 2022-02-16
Linux相关 2022-02-27
数据库技术 2022-02-20
抠敌 2023年10月23日
嚼餐 2023年10月23日
男忌 2023年10月22日
瓮仆 2023年10月22日
簿偌 2023年10月22日
扫码二维码
获取最新动态