最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

MFC对MYSQL数据库相关操作_MySQL

来源:懂视网 责编:小采 时间:2020-11-09 19:48:19
文档

MFC对MYSQL数据库相关操作_MySQL

MFC对MYSQL数据库相关操作_MySQL:记得看过有人说,现在的软件基本上都是连着数据库的,如果一个软件没有跟数据库相连,基本没什么作用。虽然这种说法略显片面,但数据库之于软件的重要也是毋庸置疑的。 MFC连接数据库应该不算是什么新鲜的命题了,方法是有好几种的,本人试了下,感觉利用My
推荐度:
导读MFC对MYSQL数据库相关操作_MySQL:记得看过有人说,现在的软件基本上都是连着数据库的,如果一个软件没有跟数据库相连,基本没什么作用。虽然这种说法略显片面,但数据库之于软件的重要也是毋庸置疑的。 MFC连接数据库应该不算是什么新鲜的命题了,方法是有好几种的,本人试了下,感觉利用My
记得看过有人说,现在的软件基本上都是连着数据库的,如果一个软件没有跟数据库相连,基本没什么作用。虽然这种说法略显片面,但数据库之于软件的重要也是毋庸置疑的。

MFC连接数据库应该不算是什么新鲜的命题了,方法是有好几种的,本人试了下,感觉利用MySQL提供的C语言API来进行操作蛮方便的,所以在此记录下相关的操作。

要用MySQL提供的C语言API,首先要包含API的头文件目录,也就是在MFC工程属性中的“包含目录”下添加MySQL安装目录的“include”文件夹。因为API是以动态链接库的形式打包的,所以还要在MFC工程属性中的“库目录”下添加MySQL安装目录的“lib”文件夹,结果如下图所示:

\

因为是动态链接库,所以在做完上面的配置后,要将MySQL安装目录下的libmysql.dll文件拷贝到MFC工程目录下,如果以后要发行的话这个也要打包进去。昨晚这一步,我们只需要在用到MySQL的头文件中包含MySQL头文件就可以正常使用此数据库了。代码如下:

#include "winsock.h"//因为数据库是通过网络连接的,必须包含网络相关头文件
#include "mysql.h"//这个没什么好说的,mysql头文件自然要包含 
#pragma comment(lib,"libmySQL.lib")//附加依赖项,也可以在工程属性中设置

做完上面的配置,我们已经可以正常的使用MySQL提供的API了,下面分门别类的来讲讲具体的操作。

连接数据库:

MYSQL m_sqlCon;
mysql_init(&m_sqlCon);//初始化数据库对象
if (!mysql_real_connect(&m_sqlCon, "localhost", "root", "123", "test", 3306, NULL, 0))//localhost:服务器地址,可以直接填入IP;root:账号;123:密码;test:数据库名;3306:网络端口 
{
	AfxMessageBox(_T("数据库连接失败!"));
	return;
}
else//连接成功则继续访问数据库,之后的相关操作代码基本是放在这里面的
{
	AfxMessageBox(_T("数据库连接成功!"));
}
mysql_close(&m_sqlCon);//关闭Mysql连接 

得到数据库中表数据:

mysql_query(&m_sqlCon, "SET NAMES 'GB2312'");//设置数据库字符格式,解决中文乱码问题
if (mysql_real_query(&m_sqlCon, "select * from 物料属性", (unsigned long)strlen("select * from 物料属性")))// 查询数据库中的"物料属性"表 
{return;}
res = mysql_store_result(&m_sqlCon);//得到存储结果集 
if (NULL == res)//如果为空则返回
{ return; }
int listrow = 0;
while (row = mysql_fetch_row(res))//重复读取行,把数据放入列表中,直到row为NULL 
{
	for (int rols = 0; rols < cols; rols++)
	{
	CString myreaddata(row[rols]);
	if (rols==0)
	{
	list->InsertItem(listrow, myreaddata);//添加第一个学生数据
	}
	else
	{
	list->SetItemText(listrow, rols, myreaddata);
	}
	}
	listrow++;
}
清空数据表内容:
mysql_query(&m_sqlCon, "SET NAMES 'GB2312'");//设置数据库字符格式,解决中文乱码问题
char *mysqlstatements = "DELETE 物料属性.*FROM 物料属性";//sql操作语句
mysql_real_query(&m_sqlCon, mysqlstatements, (unsigned long)strlen(mysqlstatements));//清空"物料属性"表 

插入数据表内容:
sprintf_s(mysqlstatements, "INSERT INTO 物料属性(物料编号,物料名称,所属类别,计量单位,样品单价,批量单价) value('%s', '%s', '%s', '%s', '%s', '%s')",
	mysqlinsertpoint[0], mysqlinsertpoint[1], mysqlinsertpoint[2], mysqlinsertpoint[3], mysqlinsertpoint[4], mysqlinsertpoint[5]); //sql操作语句
mysql_real_query(&m_sqlCon, mysqlstatements, (unsigned long)strlen(mysqlstatements));//插入数据到"物料属性"表

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

MFC对MYSQL数据库相关操作_MySQL

MFC对MYSQL数据库相关操作_MySQL:记得看过有人说,现在的软件基本上都是连着数据库的,如果一个软件没有跟数据库相连,基本没什么作用。虽然这种说法略显片面,但数据库之于软件的重要也是毋庸置疑的。 MFC连接数据库应该不算是什么新鲜的命题了,方法是有好几种的,本人试了下,感觉利用My
推荐度:
标签: 操作 数据库 相关
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top