这几天一直在学习C++下使用Mysql的方法及其中各种的问题,也看了很多Mysql的API函数,当然自己看的还是很基础的。其实对于每种数据库的操作,基本的方法都是非常类似的,大多都是connect,select,update,delete以及insert这几个操作。接下来我就将这几个步骤以代码的方式展现给大家,相信应该能对大家对mysql的编程起到一个基础模板的作用,方便大家以后对mysql数据库的了解和学习。

1.mysql的初始化initConnection:

1)mysql_init():初始化数据库

2)mysql_real_connect()(不推荐用Mysql_connect()):连接数据库

详细代码如下:

  1. bool dataBase::initConnection() {
  2. try {
  3. if (mysql_init(&m_sqlCon) == NULL) {
  4. std::cout << "初始化数据库失败" << std::endl;
  5. return false;
  6. }
  7. // localhost:服务器 root为账号密码 test为数据库名 3306为端口
  8. if (!mysql_real_connect(&m_sqlCon, host, user, pass,databaseName, port, NULL, ))
  9. {
  10. std::cout << "数据库连接失败" << std::endl;
  11. return false;
  12. }
  13. std::cout << "数据库连接成功" << std::endl;
  14. return true;
  15. }
  16. catch (...)
  17. {
  18. std::cout << "出错啦" << std::endl;
  19. return false;
  20. }
  21. }

2.mysql的查询select:

1)mysql_query():进行查询语句

2)mysql_store_result():获得查询结果

3)mysql_fetch_field()以及mysql_fetch_row():获得结果集中的内容

4)mysql_free_result()

代码如下:

  1. void dataBase::user_query() {
  2. if (mysql_query(&m_sqlCon, "select * from user")) {
  3. std::cout << "查询失败" << std::endl;
  4. return;
  5. }
  6. std::cout << "查询成功" << std::endl;
  7. MYSQL_RES *result;
  8. result = mysql_store_result(&m_sqlCon);
  9. if (result) {
  10. int row_num,col_num;
  11. row_num = mysql_num_rows(result);
  12. col_num = mysql_num_fields(result);
  13. std::cout << "共有" << row_num << "条数据,以下为其详细内容:" << std::endl;
  14. MYSQL_FIELD *fd;
  15. while (fd = mysql_fetch_field(result)) {
  16. std::cout << fd->name << "\t";
  17. }
  18. std::cout << std::endl;
  19. MYSQL_ROW sql_row;
  20. while (sql_row = mysql_fetch_row(result)) {
  21. for (int i = ; i < col_num; i++) {
  22. if (sql_row[i] == NULL) std::cout << "NULL\t";
  23. else std::cout << sql_row[i] << "\t";
  24. }
  25. std::cout << std::endl;
  26. }
  27. }
  28. if(result!=NULL)
  29. mysql_free_result(result);
  30.  
  31. }

3.mysql的插入语句insert:

1)mysql_query()通过select判断是否已经存在(可以省略)

2)通过mysql_query()进行插入

代码如下:

  1. void dataBase::user_insert(UserBody &body) {
  2. char select_user[];
  3. char query[];
  4. MYSQL_RES *result;
  5. sprintf(select_user, "select * from user where UserName='%s'", body.userName);
  6. if (mysql_query(&m_sqlCon, select_user)||!(result = mysql_store_result(&m_sqlCon))) {
  7. std::cout << "插入查询失败" << std::endl;
  8. return;
  9. }
  10. if (mysql_num_rows(result)) {
  11. std::cout << "用户已存在" << std::endl;
  12. mysql_free_result(result);
  13. return;
  14. }
  15. mysql_free_result(result);
  16. sprintf(query, "insert into user(UserName,UserPass,ConnectionNum,UseFor) values('%s','%s',%d,%d)", body.userName, body.userPass, body.connection, body.type);
  17. if (mysql_query(&m_sqlCon, query)) {
  18. std::cout << "插入数据失败" << std::endl;
  19. return;
  20. }
  21. std::cout << "插入数据成功,共插入:" <<mysql_affected_rows(&m_sqlCon)<<"行" << std::endl;
  22. }

4.mysql的修改语句update

修改与添加的步骤类似,直接贴出代码就不做赘述了。

代码如下:

  1. void dataBase::user_update(UserBody &body) {
  2. char query[];
  3. char select_user[];
  4. MYSQL_RES *result;
  5. sprintf(select_user, "select * from user where UserName='%s'", body.userName);
  6. if (mysql_query(&m_sqlCon, select_user) || !(result = mysql_store_result(&m_sqlCon))) {
  7. std::cout << "修改查询失败" << std::endl;
  8. return;
  9. }
  10. if (mysql_num_rows(result) == ) {
  11. std::cout << "要修改的用户不存在" << std::endl;
  12. mysql_free_result(result);
  13. return;
  14. }
  15. mysql_free_result(result);
  16. sprintf(query, "update user set UserPass='%s',ConnectionNum=%d,UseFor=%d where UserName='%s'", body.userPass, body.connection, body.type, body.userName);
  17. if (mysql_query(&m_sqlCon, query)) {
  18. std::cout << "修改失败" << std::endl;
  19. return;
  20. }
  21. std::cout << "修改成功,共修改:" << mysql_affected_rows(&m_sqlCon) << "行" << std::endl;
  22. }

5.mysql的删除操作delete

其实删除、修改和插入操作都是类似的,会其中一个其他应该都差不多了,我也就直接贴出代码了。

代码如下:

  1. void dataBase::user_delete(char *userName) {
  2. char query[];
  3. char select_user[];
  4. MYSQL_RES *result;
  5. sprintf(select_user, "select * from user where UserName='%s'", userName);
  6. if (mysql_query(&m_sqlCon, select_user)||!(result = mysql_store_result(&m_sqlCon))) {
  7. std::cout << "删除查询失败" << std::endl;
  8. return;
  9. }
  10. if (mysql_num_rows(result)==) {
  11. std::cout << "要删除的用户不存在" << std::endl;
  12. mysql_free_result(result);
  13. return;
  14. }
  15. mysql_free_result(result);
  16. sprintf(query, "delete from user where UserName='%s'", userName);
  17. if (mysql_query(&m_sqlCon, query)) {
  18. std::cout << "删除失败" << std::endl;
  19. return;
  20. }
  21. std::cout << "删除成功,共删除:" << mysql_affected_rows(&m_sqlCon) << "行" << std::endl;
  22. }

以上算是对Mysql中常用的一些代码的总结,有什么不完善的希望大家能够提出来,也希望这个能在平时帮到大家,起到一个模板的作用,也能方便大家对mysql的学习。我也属于一个learner,也希望能和大家在平时中相互学习。

转载请注明出处:http://www.cnblogs.com/fnlingnzb-learner/p/5829556.html。谢谢

C++使用Mysql的详细步骤及各个常用方法的代码演示:select,insert,update,delete的更多相关文章

  1. java连接mysql数据库详细步骤解析

    java连接mysql数据库详细步骤解析      第一步:下载一个JDBC驱动包,例如我用的是:mysql-connector-java-5.1.17-bin.jar      第二步:导入下载的J ...

  2. mysql数据恢复 insert\update\delete 工具MyFlash

    一.简介MyFlash是由美团点评公司技术工程部开发维护的一个回滚DML操作的工具.该工具通过解析v4版本的binlog,完成回滚操作.相对已有的回滚工具,其增加了更多的过滤选项,让回滚更加容易. 该 ...

  3. mysql 事务是专门用来管理insert,update,delete语句的,和select语句一点不相干

    1.mysql 事务是专门用来管理insert,update,delete语句的,和select语句一点不相干 2.一般来说,事务是必须满足4个条件(ACID): Atomicity(原子性).Con ...

  4. MySQL 升级详细步骤 (包括 Percona)

    MySQL 升级步骤 MySQL 5.1.72 升级到 MySQL 5.5.36 鉴于我在升级的时候遇到的麻烦问题,我觉得有必要把一些细节说清楚,免得引起误解了.感觉官方文档上的升级步骤写的比较简单, ...

  5. mysql安装详细步骤图解

    本文转自http://blog.csdn.net/fanyunlei/article/details/21454645 别看图多,其实mysql的安装十分简单,一路next即可,只是注意倒数第三步,设 ...

  6. 阿里云服务器上安装mysql的详细步骤

    阿里云安装mysql (1)下载mysql安装包,去mysql官网下载对应的包 mysql数据库官方下载网址:   https://downloads.mysql.com/archives/commu ...

  7. 安装MySQL的详细步骤

    安装步骤如下: 1.打开网址:http://www.mysql.com/ ↓ 2.选择“Download”->“Windows”(此安装步骤只是在Window10 中进行,如有需要,其他系统可参 ...

  8. Linux 破解mysql密码(详细步骤)

    当mysql密码忘记时 [root@master ~]# mysql -uroot -p1 mysql: [Warning] Using a password on the command line ...

  9. ASP.NET 连接MySQL数据库 详细步骤

    ASP.NET默认的数据库是MS SQL Server,微软的数据库产品.事实上,如果不计成本因素的话,Windows Server + IIS + MS SQL Server + ASP.NET是网 ...

随机推荐

  1. C#中Socket关闭 Close、Dispose、Shutdown、Disconnect

    An answer on StackOverflow made me think I have finally reached some glimpse of an understanding. Th ...

  2. 数据库连接出错 expected key exchange group packet form server

    数据库连接出错 expected key exchange group packet form server SSH: expected key exchange group packet form ...

  3. 使用http-server创建本地服务

    在很多情况下, 都需要开启本地http服务器来测试, 所以就需要一个简单省事的http服务器, , 以前的时候可以使用express或者webpack-dev-server来启动一个服务, 这未免有点 ...

  4. docker: Error response from daemon: driver failed programming external connectivity on endpoint jolly_shockley

    1. docker 启动image错误 docker: Error response from daemon: driver failed programming external connectiv ...

  5. centos 6.X 安装nodejs v6.11.0和npm

    下载nodejs wget -c https://nodejs.org/dist/v6.11.0/node-v6.11.0-linux-x64.tar.xz 安装gcc++ yum install - ...

  6. mha error

    MasterFailover.pm 1473 $ret =1474 $_server_manager->change_master_and_start_slave( $target, $late ...

  7. Windows核心编程 中部分代码 Delphi 实现

    // ① Delphi 使用 Interlocked 系列函数 var MyValue:Longint = ; // = Integer begin InterlockedIncrement(MyVa ...

  8. 解决cron无法运行报错:FAILED to authorize user with PAM (Module is unknown)

    查看cron运行日志 tail -f /var/log/cron 报如下错误: May 8 10:14:01 localhost crond[9399]: (root) FAILED to autho ...

  9. Python单元测试框架之pytest 1 ---如何执行测试用例

    From: https://www.cnblogs.com/fnng/p/4765112.html 介绍   pytest是一个成熟的全功能的Python测试工具,可以帮助你写出更好的程序. 适合从简 ...

  10. 关于RabbitMQ分布式集群架构

    RabbitMQ分布式集群架构和高可用性(HA) (一) 功能和原理 设计集群的目的 允许消费者和生产者在RabbitMQ节点崩溃的情况下继续运行 通过增加更多的节点来扩展消息通信的吞吐量 1 集群配 ...