C++连接使用MySQL,供大家参考,具体内容如下
定义MySQLCon类
class MySQLCon { MYSQL mysql; public: int errornum; string errortext; public: //初始化 MySQLCon(); //关闭数据库 ~MySQLCon(); //链接数据库 bool OpenConn(const char* host,const char* username,const char* pwd,const char* dbName,unsigned port=0); void GetErrorText();//获取错误文本 void Close();//关闭数据库 bool ExecuteSQL(const char* sql);//使用SQL语句,无法接收数据 bool QureySQL(const char* sql, vector<vector<string& resultSet);//使用SQL语句并接收数据(select语句) };
初始化操作
MySQLCon::MySQLCon() { if (mysql_library_init(0, nullptr, nullptr)) { cout << "CAPI初始化失败" << std::endl; getchar(); exit(1); } if (mysql_init(&mysql)==nullptr) { cout << "初始化数据库变量失败" << std::endl; getchar(); exit(1); } if (mysql_options(&mysql, MYSQL_SET_CHARSET_NAME, "gbk")) { cout << "设置连接选项失败" << std::endl; getchar(); exit(1); } }
连接到MySQL服务器
//参数分别为主机,用户名,密码,数据库名,端口号 bool MySQLCon::OpenConn(const char* host, const char* username, const char* pwd, const char* dbName, unsigned port) { //连接数据库 if (mysql_real_connect(&mysql, host, username, pwd, dbName, port, nullptr, 0)==nullptr) { cout << "连接到MySQL服务器失败" << std::endl; //获取错误文本 GetErrorText(); exit(1); return false; } return true; }
获取MySQL错误信息
void MySQLCon::GetErrorText() { //获取错误代码 errornum = mysql_errno(&mysql); //获取错误文本 errortext = mysql_error(&mysql); //打印错误代码 cout << "error num: " << errornum << std::endl; //打印错误文本 cout << "error text: " << errortext << std::endl; getchar(); }
C++中使用SQL语句
bool MySQLCon::ExecuteSQL(const char* sql) { //使用SQL语句但无法接收数据 if (mysql_real_query(&mysql, sql, strlen(sql))) { GetErrorText(); return false; } return true; }
bool MySQLCon::QureySQL(const char* sql, vector<vector<string& resultSet) { //使用SQL语句并接收数据至vector容器 if (mysql_real_query(&mysql, sql, strlen(sql))) { GetErrorText(); return false; } //创建一个MYSQL结果集 MYSQL_RES* result = mysql_store_result(&mysql); //获取行和列的总数 unsigned int rows = mysql_num_rows(result); unsigned int cols = mysql_num_fields(result); //用于记录结果集中的一条数据 MYSQL_ROW row; while (row = mysql_fetch_row(result)) { //创建一个vector容器用于储存row中的数据 vector<string> lineDate; for (int i = 0; i < cols; i++) { if (row[i]) { //将row中每一列的数据存入lineDate中 lineDate.push_back(row[i]); } else { lineDate.push_back(""); } } //在resultSet中存入整行数据 resultSet.push_back(lineDate); } //释放结果集 mysql_free_result(result); return true; }
关闭数据库
void MySQLCon::Close() { mysql_close(&mysql); } MySQLCon::~MySQLCon() { Close(); mysql_library_end(); }
示例主函数
int main() { MySQLCon c_apiconn; c_apiconn.OpenConn("127.0.0.1", "root", "136119", "fancy"); string sql = "use fancy;"; vector<vector<string data; c_apiconn.ExecuteSQL(sql.c_str()); sql = "select * from fancy.info;"; c_apiconn.QureySQL(sql.c_str(), data); for (int i = 0; i < data.size(); i++) { for (int j = 0; j < data[i].size(); j++) { cout << data[i][j] << "\t"; } cout << endl; } return 0; }
输出内容
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
标签:
C++,mysql
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com
暂无“C++连接使用MySQL的方法”评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
2024年10月06日
2024年10月06日
- 群星《前途海量 电影原声专辑》[FLAC/分轨][227.78MB]
- 张信哲.1992-知道新曲与精丫巨石】【WAV+CUE】
- 王翠玲.1995-ANGEL【新艺宝】【WAV+CUE】
- 景冈山.1996-我的眼里只有你【大地唱片】【WAV+CUE】
- 群星《八戒 电影原声带》[320K/MP3][188.97MB]
- 群星《我的阿勒泰 影视原声带》[320K/MP3][139.47MB]
- 纪钧瀚《胎教古典音乐 钢琴与大提琴的沉浸时光》[320K/MP3][148.91MB]
- 刘雅丽.2001-丽花皇后·EMI精选王【EMI百代】【FLAC分轨】
- 齐秦.1994-黄金十年1981-1990CHINA.TOUR.LIVE精丫上华】【WAV+CUE】
- 群星.2008-本色·百代音乐人创作专辑【EMI百代】【WAV+CUE】
- 群星.2001-同步过冬AVCD【环球】【WAV+CUE】
- 群星.2020-同步过冬2020冀待晴空【环球】【WAV+CUE】
- 沈雁.1986-四季(2012梦田复刻版)【白云唱片】【WAV+CUE】
- 纪钧瀚《胎教古典音乐 钢琴与大提琴的沉浸时光》[FLAC/分轨][257.88MB]
- 《国语老歌 怀旧篇 3CD》[WAV/分轨][1.6GB]