• ADADADADAD

    如何使用MySql的API连接MySql数据库[ mysql数据库 ]

    mysql数据库 时间:2024-11-28 13:03:20

    作者:文/会员上传

    简介:

    C++连接MySQL数据库有两种方式:1、通过MySQL 的C API(决定使用这种方式)也可以使用MySQL++ 。[Mysql++是官方发布的、一个为MySQL设计的C++语言的API。Mysql++为Mysql的C-Api的

    以下为本文的正文内容,内容仅供参考!本站为公益性网站,复制本文以及下载DOC文档全部免费。

    C++连接MySQL数据库有两种方式:

    1、通过MySQL 的C API(决定使用这种方式)

    也可以使用MySQL++ 。

    [Mysql++是官方发布的、一个为MySQL设计的C++语言的API。Mysql++为Mysql的C-Api的再次封装,它用STL(Standard Template Language)开发并编写,并为C++开发者提供像操作STL容器一样方便的操作数据库的一套机制]

    2、通过MySQL的Connector c++

    MySQL C++ Driver的实现基于JDBC规范。

    MySQL Connector/C++是由Sun Microsystems开发的MySQL连接器。它提供了基于OO的编程接口与数据库驱动来操作MySQL服务器。与许多其他现存的C++接口实现不同,Connector/C++遵循了JDBC规范。也就是说,Connector/C++ Driver的API主要是基于Java语言的JDBC接口。JDBC是java语言与各种数据库连接的标准工业接口。Connector/C++实现了大部分JDBC规范。

    学习内容:对如何使用MySql的API连接MySql数据库

    一、工程设置

    将工程的头文件路径指向Mysql安装目录的同文件mysql.h所在的位置,将连接库路径指向libmysql.lib所在的路径:


    <br>具体配置步骤:
    1、项目属性页的C/C++->常规->附加包含目录指向:C:\Program Files\MySQL\MySQL Server 5.1\include
    2、项目属性页的链接器->常规->附加库目录指向:C:\Program Files\MySQL\MySQL Server 5.1\lib\opt.
    3、将链接器->输入->附加依赖项中添加libmysql.lib(也可以在程序代码的开始处加上#pragma comment(lib,"D:\Program Files\MySQL\MySQL Server 5.6\lib\libmysql.lib") 来导入libmysql.lib)
    4、将D:\Program Files\MySQL\MySQL Server 5.6\lib下的libmysql.dll拷到项目的debug文件夹,即跟输出文件一个文件夹下

    二、连接Mysql和从MySql中取出数据的API

    简单的连接数据库,获取数据库信息:

    #include<windows.h>#include<mysql.h>#include<string>#include<iostream>usingnamespacestd;intmain(){constcharuser[]="root";constcharpswd[]="root";constcharhost[]="localhost";constchartable[]="bookdb";//数据库名unsignedintport=3306;MYSQLmyCont;MYSQL_RES*result;MYSQL_ROWsql_row;intres;mysql_init(&myCont);if(mysql_real_connect(&myCont,host,user,pswd,table,port,NULL,0)){mysql_query(&myCont,"SETNAMESGBK");//设置编码格式res=mysql_query(&myCont,"select*frombookInfo");//查询if(!res){result=mysql_store_result(&myCont);if(result){while(sql_row=mysql_fetch_row(result))//获取具体的数据{cout<<"BOOKNAME:"<<sql_row[1]<<endl;cout<<"PRICE:"<<sql_row[2]<<endl;}}}else{cout<<"querysqlfailed!"<<endl;}}else{cout<<"connectfailed!"<<endl;}if(result!=NULL)mysql_free_result(result);mysql_close(&myCont);system("pause");return0;}
    三、MySQL常用的API接口

    mysql_affected_rows() 返回被最新的UPDATE, DELETE或INSERT查询影响的行数。
    mysql_close() 关闭一个服务器连接。
    mysql_connect() 连接一个MySQL服务器。该函数不推荐;使用mysql_real_connect()代替。
    mysql_change_user() 改变在一个打开的连接上的用户和数据库。
    mysql_create_db() 创建一个数据库。该函数不推荐;而使用SQL命令CREATE DATABASE。
    mysql_data_seek() 在一个查询结果集合中搜寻一任意行。
    mysql_debug() 用给定字符串做一个DBUG_PUSH。
    mysql_drop_db() 抛弃一个数据库。该函数不推荐;而使用SQL命令DROP DATABASE。
    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() 初始化一个一行一行地结果集合的检索。

    如何使用MySql的API连接MySql数据库.docx

    将本文的Word文档下载到电脑

    推荐度:

    下载
    热门标签: 数据库mysqlapi