VC++连MySQL中的一些小知识点

本文介绍了使用VC++连接MySQL数据库的过程及注意事项,包括MySQL的安装配置、管理工具的选择、C接口的使用方法以及常见错误排查。

此文章主要介绍的是VC++连MySQL中的一些小知识点,传说中MySQL数据库的性能很好,所以今天准备对其测试一下,假如效果真的很好的话就把数据库换成MySQL.但没想到这一弄就折腾了两个小时.

唉!不过还好现在都解决了,恩,现在把前两个小时里学到的东西记在这里,以备不时之需哈~

MySQL是开源的,网上很容易就下的到MySQL Dowload.我下的是WINDOWS版的,安装很简单,这里就不多说了,但是别忘了还得下个管理工具.MySQL不像MSSQL那样带有图形界面的管理工具,图形界面程序它只带了重新配置MySQL的MySQLInstanceConfig.exe,

剩下的就是一堆命令行程序了.说到重新配置MySQL,我得提醒下,MySQLInstanceConfig.exe如果停在了最后一步Start Service那里报错的话,就从新安装MySQL吧,无论怎么配置都过不了那步.不过具体应该可以手工改好的,不过我没搞懂哈,直接重装就好了.MySQL管理工具有很多,还有PHP版的,我用的是MySQL GUI Tools 5.0,算是官方版的吧,挺好用的

MySQL有提供C的API接口,当然我就直接用的它了,因为传说它比用ADO要快一些.在MySQL的安装目录下你会找到include和lib文件夹(完全安装模式下),里面分别是C接口的头文件和库文件,库文件只用libmysql.lib就好了,头文件的话代码里只需引用mysql.h,

当然编译的时候mysql.h还引用了同目录下的其它文件,所以我就把include文件夹里的所有文件都拷贝到VC++的include文件夹里的,只把libmysql.lib拷贝到了VC++的lib文件夹里.

我新建的是个MFC程序,因为MySQL需要网络支持,所以在MFC程序创建向导里要选上"Windows 套接字",否则编译的时候会报SOCKET相关的错误(在这里我折腾了半个小时大概 -.-|||).mysql.h必须在windows.h和sockets头文件之后被引用,MFC里我就把它放到stdafx.h的最后一行了.最后别忘了在连接器参数里加上libmysql.lib的连接,否则会报错:XXX函数未声明.

VC++连MySQL中要用到的MySQL函数:

MYSQL* mysql_init(NULL) //初始化一个MYSQL对象,后面的操作要用到

MYSQL *mysql_real_connect(MYSQL *mysql, const char *host, const char *user, const char *passwd, const char *db, unsigned int port, const char *unix_socket, unsigned long client_flag) //建立连接,db是要访问的数据库,unix_socket和client_flag通常为NULL就可以了.连接成功返回第一个参数,否则失败

nt mysql_query(MYSQL *mysql, const char *stmt_str) //执行一个查询,成功时返回0

MYSQL_RES *mysql_store_result(MYSQL *mysql) //获取查询返回的结果集,失败时返回0

unsigned int mysql_num_fields(MYSQL_RES *result) //获取返回结果集的字段数量

MYSQL_ROW mysql_fetch_row(MYSQL_RES *result) //获取一行记录,并将移动到下个记录,返回NULL时则遍历完了所有行或出错.MYSQL_ROW类型是个字符串数组,下标为[0,columnLength-1]

void mysql_free_result(MYSQL_RES *result) //释放结果集

void mysql_close(MYSQL *mysql) //关闭连接

这里是具体代码(写的很粗哈~测试嘛~)

  1. MYSQL mysql;  
  2. mysql_init(&mysql);  
  3. ASSERT(mysql_real_connect(&mysql, "127.0.0.1", "alacky", "password", "Test", 3306, 0, 0));  
  4. ASSERT(mysql_query(&mysql, "SELECT * FROM maxTest") == 0);  
  5.  MYSQL_RES *result;  
  6. result = mysql_store_result(&mysql);  
  7. MYSQL_ROW row;  
  8. ULONG colLen = mysql_num_fields(result);  
  9. CString datas = "";  
  10.  while(row = mysql_fetch_row(result))  

遍历每行记录

  1. {  
  2. for(ULONG i=0; i<colLen; i++)   
  3. {  
  4. datas += row[i] ? row[i] : "NULL";  
  5. datas += "\t";  
  6. }  
  7. datas += "\n\n";  
  8. }  
  9. mysql_free_result(result);  
  10. mysql_close(&mysql); 
考虑柔性负荷的综合能源系统低碳经济优化调度【考虑碳交易机制】(Matlab代码实现)内容概要:本文围绕“考虑柔性负荷的综合能源系统低碳经济优化调度”展开,重点研究在碳交易机制下如何实现综合能源系统的低碳化与经济性协同优化。通过构建包含风电、光伏、储能、柔性负荷等多种能源形式的系统模型,结合碳交易成本与能源调度成本,提出优化调度策略,以降低碳排放并提升系统运行经济性。文中采用Matlab进行仿真代码实现,验证了所提模型在平衡能源供需、平抑可再生能源波动、引导柔性负荷参与调度等方面的有效性,为低碳能源系统的设计与运行提供了技术支撑。; 适合人群:具备一定电力系统、能源系统背景,熟悉Matlab编程,从事能源优化、低碳调度、综合能源系统等相关领域研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①研究碳交易机制对综合能源系统调度决策的影响;②实现柔性负荷在削峰填谷、促进可再生能源消纳中的作用;③掌握基于Matlab的能源系统建模与优化求解方法;④为实际综合能源项目提供低碳经济调度方案参考。; 阅读建议:建议读者结合Matlab代码深入理解模型构建与求解过程,重点关注目标函数设计、约束条件设置及碳交易成本的量化方式,可进一步扩展至多能互补、需求响应等场景进行二次开发与仿真验证。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值