C++通过MySQL连接本地数据库并查询数据

需积分: 10 8 下载量 146 浏览量 更新于2024-09-18 收藏 2KB TXT 举报
本篇文章主要介绍了如何在C++环境中通过MySQL连接数据库并执行SQL查询。首先,作者使用了必要的库文件,如`mysql.h`和`winsock.h`,来支持与MySQL数据库的交互。程序的关键部分包括: 1. **初始化连接**: `mysql_init()`函数用于初始化一个MySQL连接对象,而`mysql_real_connect()`函数则实际建立连接。在本例中,连接参数包括主机地址("localhost")、用户名("root")、密码("sa")以及端口号(3306)。如果连接失败,会输出"No con"。 2. **设置数据库连接选项**: 在连接建立后,设置`reconnect`属性为1,表示在连接断开时尝试自动重新连接。接着调用`mysql_select_db()`选择数据库("test"),然后尝试设置字符集为GBK,使用`mysql_query()`执行SQL语句"SET NAMES gbk"。 3. **执行SQL查询并获取结果**: 使用`mysql_query()`执行SQL命令"SELECT * FROM user",如果查询成功,将结果存储在`mysql_store_result()`中。之后,通过`mysql_num_fields()`获取字段数量,并使用`mysql_fetch_field()`遍历每个字段名。查询结果的数量由`mysql_num_rows()`提供,然后逐行打印数据,包括字段名和对应的值。 4. **错误处理**: 如果SQL查询失败,会输出相应的错误消息,如"Couldn't execute \"SELECT * FROM user\" on server."。 5. **清理资源**: 最后,释放结果集资源并关闭连接,使用`mysql_free_result()`和`mysql_close()`确保资源管理的正确性。 这篇文章展示了C++编程语言中连接MySQL数据库的基本步骤,对于学习和开发C++应用程序与MySQL数据库交互非常有帮助。通过这个示例,读者可以了解到如何处理连接、执行SQL查询、获取结果和处理错误等核心操作。