MySQL增、删、改、查基础操作(C++)
系统平台:Centos7
MySQL版本:5.7.19
连接MySQL数据库
MySQL::MySQL(string host, string user, string passwd, string db, unsigned port)
{
m_host = host;
m_user = user;
m_passwd = passwd;
m_dbname = db;
m_port = port; mysql_init(&connect);
} bool MySQL::connectDB()
{
if (!mysql_real_connect(&connect, m_host.c_str(), m_user.c_str(), m_passwd.c_str(), m_dbname.c_str(), m_port, NULL, ))
{
cout << "mysql connect error with " << mysql_errno(&connect) << endl;
return false;
}
return true;
}
增:
bool MySQL::Insert(string table, map<string, string> values)
{
sql.clear();
if (values.size() == )
{
cout << "Input Error!!!" << endl;
return false;
}
else
{
sql = "INSERT INTO " + table + "(";
auto iter = values.begin();
while (iter != values.end())
{
sql += iter->first + ',';
iter++;
}
sql = sql.substr(, sql.rfind(',')) + ") VALUES("; iter = values.begin();
while (iter != values.end())
{
sql += string("\"") + iter->second + "\",";
iter++;
}
sql = sql.substr(, sql.rfind(',')) + ");";
ret = mysql_query(&connect, sql.c_str());
if (ret != )
{
cout << "mysql query error with " << ret << " Reason: " << mysql_error(&connect) << endl;
return false;
}
ret = mysql_query(&connect, "commit");
return true;
}
}
删:
bool MySQL::Delete(string table, map<string, string> values)
{
sql.clear();
if (values.size() == )
{
cout << "Input Error!!!" << endl;
return false;
}
else
{
sql = "DELETE FROM " + table + " WHERE ";
auto iter = values.begin();
while (iter != values.end())
{
sql += iter->first + " = " + iter->second + " and ";
iter++;
}
sql = sql.substr(, sql.rfind("and")) + ";";
ret = mysql_query(&connect, sql.c_str());
if (ret != )
{
cout << "mysql query error with " << ret << " Reason: " << mysql_error(&connect) << endl;
return false;
}
ret = mysql_query(&connect, "commit");
return true;
}
}
改:
bool MySQL::Update(string table, map<string, string> values)
{
sql.clear();
if (values.size() == )
{
cout << "Input Error!!!" << endl;
return false;
}
else
{
sql = "UPDATE " + table + " SET ";
auto iter = values.begin();
while (iter != values.end())
{
sql += iter->first + " = \"" + iter->second + "\" and ";
iter++;
}
sql = sql.substr(, sql.rfind("and")) + ";";
ret = mysql_query(&connect, sql.c_str());
if (ret != )
{
cout << "mysql query error with " << ret << " Reason: " << mysql_error(&connect) << endl;
return false;
}
ret = mysql_query(&connect, "commit");
return true;
}
}
查:
bool MySQL::Select(string table, map<string, string> values)
{
sql.clear(); if(values.size() == )
sql = "SELECT * FROM " + table + " ;";
else
{
sql = "SELECT * FROM " + table + " where ";
auto iter = values.begin();
while (iter != values.end())
{
sql += iter->first + " = \"" + iter->second + "\" and ";
iter++;
}
sql = sql.substr(, sql.rfind("and")) + ";";
} ret = mysql_query(&connect, sql.c_str());
if (ret != )
{
cout << "mysql query error with " << ret << " Reason: " << mysql_error(&connect) << endl;
return false;
} showDetails(connect); return true;
}
自己编写sql语句查询:
bool MySQL::Query(string cmd)
{
size_t pos = cmd.find("select");
if (pos < || pos > cmd.size())
{
sql = cmd;
ret = mysql_query(&connect, sql.c_str());
if (ret != )
{
cout << "mysql query error with " << ret << " Reason: " << mysql_error(&connect) << endl;
return false;
}
return true;
}
else
{
ret = mysql_query(&connect, sql.c_str());
if (ret != )
{
cout << "mysql query error with " << ret << " Reason: " << mysql_error(&connect) << endl;
return false;
}
showDetails(connect);
return true;
}
}
MySQL执行完查询语句后会返回一个结果集,使用showDetails()函数输出结果集:
void MySQL::showDetails(MYSQL connect)
{
int col = mysql_field_count(&connect); res = mysql_store_result(&connect);
if (res == NULL)
{
cout << "mysql store result error with " << mysql_error(&connect) << endl;
exit(-);
} fields = mysql_fetch_fields(res);
for (int i = ; i < col; ++i)
cout << setw() << fields[i].name << " | ";
cout << endl; while ((row = mysql_fetch_row(res)))
{
for (int i = ; i < col; ++i)
{
if (row[i] == NULL)
cout << setw() << "NULL | ";
else
cout << setw() << row[i] << " | ";
}
cout << endl;
}
}
完整代码详见GitHub:https://github.com/MasterMeng/MySQLOperate
MySQL增、删、改、查基础操作(C++)的更多相关文章
- php5.4以上 mysqli 实例操作mysql 增,删,改,查
<?php //php5.4以上 mysqli 实例操作mysql header("Content-type:text/html;charset=utf8"); $conn ...
- Go语言之进阶篇mysql增 删 改 查
一.mysql操作基本语法 1.创建名称nulige的数据库 CREATE DATABASE nulige DEFAULT CHARSET utf8 COLLATE utf8_general_ci; ...
- 好用的SQL TVP~~独家赠送[增-删-改-查]的例子
以前总是追求新东西,发现基础才是最重要的,今年主要的目标是精通SQL查询和SQL性能优化. 本系列主要是针对T-SQL的总结. [T-SQL基础]01.单表查询-几道sql查询题 [T-SQL基础] ...
- iOS sqlite3 的基本使用(增 删 改 查)
iOS sqlite3 的基本使用(增 删 改 查) 这篇博客不会讲述太多sql语言,目的重在实现sqlite3的一些基本操作. 例:增 删 改 查 如果想了解更多的sql语言可以利用强大的互联网. ...
- django ajax增 删 改 查
具于django ajax实现增 删 改 查功能 代码示例: 代码: urls.py from django.conf.urls import url from django.contrib impo ...
- iOS FMDB的使用(增,删,改,查,sqlite存取图片)
iOS FMDB的使用(增,删,改,查,sqlite存取图片) 在上一篇博客我对sqlite的基本使用进行了详细介绍... 但是在实际开发中原生使用的频率是很少的... 这篇博客我将会较全面的介绍FM ...
- ADO.NET 增 删 改 查
ADO.NET:(数据访问技术)就是将C#和MSSQL连接起来的一个纽带 可以通过ADO.NET将内存中的临时数据写入到数据库中 也可以将数据库中的数据提取到内存中供程序调用 ADO.NET所有数据访 ...
- MVC EF 增 删 改 查
using System;using System.Collections.Generic;using System.Linq;using System.Web;//using System.Data ...
- python基础中的四大天王-增-删-改-查
列表-list-[] 输入内存储存容器 发生改变通常直接变化,让我们看看下面列子 增---默认在最后添加 #append()--括号中可以是数字,可以是字符串,可以是元祖,可以是集合,可以是字典 #l ...
- 【转】Android 增,删,改,查 通讯录中的联系人
一.权限 操作通讯录必须在AndroidManifest.xml中先添加2个权限, <uses-permission android:name="android.permission. ...
随机推荐
- nginx配置文件说明(包含IP黑名单、代理反射、负载均衡的配置)
先看下nginx配置文件整体结构 图片来源51cto 配置文件及注解: #运行用户 主模块指令,指定Nginx Worker进程运行用户以及用户组,默认由nobody账号运行 user nobody; ...
- GPS坐标与百度坐标转换
百度对外接口的坐标系,都是经过国家测绘局加密处理,符合国家测绘局对地理信息保密要求. 国际经纬度坐标标准为WGS-84,国内必须至少使用国测局制定的GCJ- 02,对地理位置进行首次加密.百度坐标在此 ...
- 给select赋值之后,再点击选择下拉值时,显示一值不变的解决
在一个项目需求中,请求数据,得到的数据dataAll渲染到页面的select下拉表单中,当时是需要一进页面就要默认选中第一个选项,所以直接将dataAll的第一个索引值赋值给了表单的绑定值formVa ...
- android 获得存储设备状态
1.获取存储器总大小,可用大小 File path= Environment.getExternalStorageDirectory();StatFs fs = new StatFs(path.get ...
- 用hash存数组|得地址|取地址
#!/usr/bin/perl -w use strict; my %hash = %{&collect};my $arr_ad=$hash{'a'};print "$arr_ad\ ...
- Work Scheduling(带反悔的贪心)
https://www.luogu.org/problem/P2949 题目描述 Farmer John has so very many jobs to do! In order to run th ...
- Android activity 亮度调整
注意点 screenBrightness 取值范围0-1 不是0-255一定要注意 scanForActivity(context) 是根据上下文获取所在的activity如果直接在activity ...
- Zblog主题模板自适应手机响应式ZblogPHP简洁博客主题
Z-blog PHP版本简洁主题模板 特点简洁舒适 手机移动端自适应,完美有利于优化 代码结构利于编辑 对于不懂代码的,也非常适合简答后台简答 PC端侧边栏下拉跟随,无论下面有多长,导航侧边栏都只在左 ...
- CentOS 配置国内源
阿里云Linux安装镜像源地址:http://mirrors.aliyun.com/ CentOS系统更换软件安装源 第一步 备份你的原镜像文件,以免出错后可以恢复. mv /etc/yum.repo ...
- HTML颜色表
1.配色原则 2.HTML颜色表 颜色名列表 单击一个颜色名或者16进制值,就可以查看与不同文字颜色搭配的背景颜色 3.总参考表: