vs2010 mfc 怎么链接 mysql数据库

vs2010 mfc 怎么链接 mysql数据库,第1张

新建一个工程名叫mysql,编程环境选择c#,然后选择windows窗体应用程序,新建一个窗体用于显示查询到sql数据库的数据集

从工具箱向form1窗体上拖一个按钮和datagridview控件,按钮是触发连接数据库获取数据集,按钮的名称为显示,datagridview控件是用于显示数据集内容

单击解决方案资源管理器中的引用文件夹然后右键选择添加引用,选择浏览后打开mysql.data.dll,这是c#连接mysql数据库的动态库,里面封装了很多常用的 *** 作数据库的方法

在解决方案资源管理器中的form1.cs的代码中加入using MySql.Data.MySqlClient这就是代码中的实际引用mysql.data.dll中的内容,有了这个c#就能很方便地 *** 作sql数据库

在按钮的单击事件中添加如下代码

string str = "Server=127.0.0.1User ID=rootPassword=123456Database=testCharSet=gbk"

MySqlConnection con = new MySqlConnection(str)//实例化链接

con.Open()//开启连接

string strcmd = "select * from user"

MySqlCommand cmd = new MySqlCommand(strcmd, con)

MySqlDataAdapter ada = new MySqlDataAdapter(cmd)

DataSet ds = new DataSet()

ada.Fill(ds)//查询结果填充数据集

dataGridView1.DataSource = ds.Tables[0]

con.Close()//关闭连接

使用navicat软件在数据库test中新建表user,然后新建两个字段username和password(图中的栏位),navicat软件是mysql的图形化界面工具,负责新建表以及备份等数据库 *** 作,直观地通过界面来 *** 作

7

数据库建好后就可以执行工程了,单击显示按钮执行结果如下,出现username和password说明数据库连接成功,由于没有添加数据所以下面为空

一、首先安装mysql:我这里用的版本是mysql-essential-5.1.45-win32.msi。安装时遇到一个小问题在这里说一下:首次安装到最后一步启动服务时卡住了,电脑死机,我强制退出,结果不能正常运行,然后卸载重装,由于第一次设置了密码,即使卸载了文件依然存在,所以第二次安装遇到设置密码时它出现要输入前一次设置的密码,在这里什么都不要输入,不然在最后一步会出错(我重装了好几次,才在baidu上查到是这个问题)。

2

二、VC6.0的设置

(1)打开VC6.0 工具栏Tools菜单下的Options选项,在Directories的标签页中右边的“Show directories for:”下拉列表中选中“Includefiles”,然后在中间列表框中添加你本地安装MySQL的include目录路径。(我的是D:\Program Files\MySQL\MySQL Server 5.0\include)。

(2)在上面说到的“Show directories for:”下拉列表中选中“Library files”,然后添加你本地安装MySQL的Lib目录路径。Lib目录下还有debug和opt两个目录,建议选debug。(我的是D:\Program Files\MySQL\MySQL Server 5.0\lib\debug)。

(3)在“Project settings->Link:Object/library modules”里面添加“libmysql.lib”。

(4)在你要连接数据库的文件里加入#include "winsock.h"和#include "mysql.h"两个文件,这里要注意这两个头文件的顺序不要颠倒,否则会报错(这个问题害我baidu了一个上午)。

3

三、数据库、表的创建

打开“开始->所有程序->MySQL->MySQL Server 5.0->MySQL Command Line Client.exe”,如果没有设置密码就直接按回车,会提示服务器启动成功。

mysql>SHOW DATABASES//显示所有的数据库,注意一定要 敲“”后再按回车

mysql>CREATE DATABASE mydb//创建数据库mydb

mysql>USE mydb//选择你所创建的数据库mydb

mysql>SHOW TABLES//显示数据库中的表

mysql>CREATE TABLE mytable (username VARCHAR(50), password VARCHAR(200),)//创建一个表mytable: 用户名;密码

mysql>DESCRIBE mytable//显示表的结构

4

四、VC编程

MYSQL mysql//数据库连接句柄

mysql_init (&mysql)

if(!mysql_real_connect(&mysql,"localhost","root","dxd","mydb",3306,NULL,0))

{//mydb为你所创建的数据库,3306为端口号,可自行设定

AfxMessageBox("数据库连接失败")

return FALSE

}

5

五、通过上述设置、连接即可对数据库 *** 作了。

首先,应该熟悉基本的sql语句,至少包括数据库的创建,建表以及表的增、删、改、查。这是 *** 作所有数据库的根本。

然后,因为具体的数据库有其自身的特性,你使用的是MySQL,那么你需要了解MySQL里面那些相应 *** 作的具体语句。我的建议是,先安装好MySQL,在命令行登录连接数据库,然后在命令行中练习,直到对数据库的基本 *** 作(特别是表的增删改查)都很熟练。至于MySQL的可视化界面,那只是为了方便这些 *** 作的。如果你只是弄一个小程序,可以不用可视化界面。

之后,应该学习如何在程序中 *** 作数据库。这个我想和MFC还是C++没有太大的关系。程序中使用数据库大体上可以分为以下几步:

加载驱动

建立数据库的连接

通过上面的连接获取语句对象

通过语句对象执行具体的sql语句,获取并处理结果集

关闭连接

这每一步都有一些小的知识点,需要你自己去学习。比如加载驱动可能涉及驱动包,建立连接需要知道程序中连接MySQL的url写法以及用户名密码,获取语句对象分statement和preparestatement,执行sql语句分查询和更新两类,关闭连接要有先后等等。这些网上应该都能查到资料,而且 *** 作的步骤都是死的,所以只要会了还是不难。我的建议是,先自己写个小程序,然后实现在这个程序里面对数据库进行 *** 作,只要能够在这个程序里对数据库进行查询了,那么这个流程你也就熟悉了,那些复杂的 *** 作也就不难实现了。

另外,在程序中 *** 作数据库和在命令行中 *** 作数据库相差不大,所以练习好在命令行中使用数据库很重要。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7554012.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-07
下一篇 2023-04-07

发表评论

登录后才能评论

评论列表(0条)

保存