
编写Excel VBA工具,连接并 *** 作Mysql 数据库。
系统环境:
OS:Win7 64位 英文版
Office 2010 32位 英文版
1、VBA连接MySql前的准备
Tools--->References---->引用
勾选Microsoft ActiveX Data Objects 28 Librarys 和Microsoft ActiveX Data Objects Recordset 28 Librarys
2、安装Mysql ODBC连接服务
下载连接:>
注意:这里使用32位的版本
下载上图中Windows(x86,32-bit),Zip Archive版本,在测试中,使用64位的版本无法连接到Mysql
把下载上述文件拷贝放到资源管理器里,放到合适位置,解压,点击里面的installbat批处理文件。
从“控制面板”--->“管理工具”---->ODBC,打开以后,从这个里面无法看到Mysql的驱动,实际上使用的是下面32位的ODBC驱动
C:\Windows\SysWOW64\文件夹下的odbcca32exe
3连接示例
Sub TestConnectTodb() Dim conn As ADODBConnection Dim rs As ADODBRecordset Set conn = New ADODBConnection Set rs = New ADODBRecordset connConnectionString = "Driver={MySQL ODBC 53 Unicode Driver};Server=localhost;Port=3306;Database=db_hptms;Uid=root;Pwd=123456;OPTION=3;" connOpen rsOpen "select fdEmpNo,fdEmpName from tbUser", conn With ThisWorkbookWorksheets("MySqlData") Visible = True Range("a1:b1")Value = Array("EmpNo", "EmpName") Range("A2")CopyFromRecordset rs Activate End With rsClose: Set rs = Nothing connClose: Set conn = Nothing MsgBox "处理完毕", vbOKOnly, "提示信息"End Sub
上述示例经过测试,可以正常连接到Mysql数据库,这里注意使用的ODBC连接的版本是32位,在测试中,使用64位的,始终无法正常打开连接。
首先建议尽量避免使用自动级联 *** 作,尤其是更新。这在以后开发中会出很多问题的。
两种方法:
1把两个表需要关联的字段,设置主外键关联,然后设置它们级联更新和删除就行了;
2就是给一个表建立触发器,当插入或更新的时候,自动更新另一个表。
试试吧!GOODLUCK!
在基于微软IIS/PWS的网络平台上,通过服务器端运行的ASP程序来访问后台数据库,是一种最常见的模式了。而对于小型的数据库应用需求,微软的Access数据库,应该是与ASP程序配套使用的首选。由于Access数据库的ODBC驱动程序支持的SQL指令全,执行效率高,所以Access后台数据库+ASP服务器端程序+客户端IE浏览器,是一个精练实用高效的组合模式。
在这种使用模式中,ASP程序无疑是最重要的,是沟通客户端和后台数据库之间的桥梁。在ASP程序中,通过VB Script,建立对Access数据库的连接,是客户能够访问后台数据库的前提。
一、建立Access数据库连接的常用方法
在ASP中建立对Access数据库连接的一般格式如下:
<%
DbPath=ServerMapPath(数据库名)
Set Conn=ServerCreatObject(“ADODBConnection”)
ConnOpen “driver=;dbq=”& DbPath
Set rs=ServerCreatObject(“ADODBRecordset”)
RsOpen 数据表名或SQL指令,Connection对象,Recordset类型,锁定类型
… …
%>
它的各步骤及参数意义如下:
第一行程序:利用Server对象的MapPath函数,取得要打开数据库的完整的文件路径,并存储在变量DbPath中。这其中,数据库名是我们需要指定的参数,应该用我们要打开的数据库的实际名称替代。如果数据库名是直接作为常量出现,要用引号将其括起来,并且不能丢掉扩展名。例如数据库是Testmdb,则该行程序成为:DbPath=ServerMapPath(“Testmdb”)。
第二行程序:建立一个ADO对象集中的Connection对象,也即连接对象。这是建立数据库连接的初始步骤。执行这行程序后,Conn成为一个连接对象。
第三行程序:利用连接对象Conn的Open方法打开一个指定的数据库。因为我们要打开的是Access数据库,所以要指定ODBC驱动程序参数,表示要透过Access的ODBC驱动程序来访问数据库:driver=;。另一个参数dbq= & DbPath,运算后等效于dbq=ServerMapPath(数据库名) ,是利用了第一行的ServerMapPath(数据库名)函数,用来指定要打开的数据库文件。到这里,就已经打开了数据库名指定的数据库。如果数据库名是“testmdb”,则打开Access数据库Testmdb。在这一行里指定的参数,要严格按照格式原样写出,不能省略或改动,也没有可变参数。
第四行程序:建立一个ADO对象集中的Recordset对象,以便利用Recordset对象 *** 作数据库(当然,这只是对数据库 *** 作的多种方式之一)。执行这行后,rs就成为一个Recordset对象。
第五行程序:利用rs对象的Open方法打开数据库中的数据表。这其中有四个参数,其意义如下:
数据表名或SQL指令串:在这个参数里指定要打开的数据库内的数据表名称,或者是用SQL的Select指令串确定的数据表的指定范围数据,例如,数据库Testmdb中有数据表Number,则该参数成为“Number”,注意引号不能丢;若想打开数据表Number中xh字段值小于90的数据记录,则该参数可能成为如下的形式:
“Select From Number Where xh < 90”。
Connection对象:指定已经打开的数据库的Connection对象,在这里固定是Conn,注意无须引号的。
Recordset类型:表示打开数据表的方式,有四种选择。数字0表示只读方式,且当前记录只能下移;数字1表示可读写方式,当前记录可自由上下移动,但不能及时看到别的用户建立的新记录,除非重新启动;数字2表示可读写方式,当前记录可自由移动,而且可以及时看到别的用户增加的新记录;数字3表示只读方式,但当前记录可以自由移动。一般选择2为好,除非为了禁止数据被修改。
锁定类型:这个参数指定数据库的锁定功能。因为网络上的数据库都是多用户的,很可能同时有多个用户在 *** 作数据库。为了避免错误,让同一时间只可能有一个用户修改数据,就要用锁定功能。有四种选择:数字1表示只读方式锁定,用户不能更改数据;数字2表示悲观锁定,当一个用户用rs对象开始修改数据时就锁定数据库,直到用户用rsUpdate更新记录后,才解除锁定;数字3表示乐观锁定,只有在数据写入数据库中时候才锁定,不保险,慎用!数字4表示批次乐观锁定,只有在使用rsUpdateBatch成批更新数据时候才锁定数据记录。属于很少使用的。一般地,使用悲观锁定比较安全,但是效率要低些。
二、使用Recordset对象 *** 作数据
用上面的方法打开数据库,是利用了Recordset对象建立的数据库连接,然后的对数据 *** 作,也要使用该对象。
用rsopen “数据表名”,Conn,2,2 方式打开数据表,就可以方便的对数据进行 *** 作:
常见的 *** 作对象:
rsaddnew :添加一个新记录在数据表末尾。
rsdelete :删除当前记录。
rseof :判断是否已过最后记录。
rsbof :判断是否移过首记录。
rsupdate :数据修改生效。
rs(“字段名”):当前记录指定字段的值。
从数据表中提取数据:用x=rs(“字段名”)的格式,提取数据表中当前记录指定字段的值。
向数据表中填入或修改数据:用rs(“字段名”)=数据值或变量的方式,修改当前记录指定字段的值。
三、使用SQL指令 *** 作数据库
在使用SQL指令对数据库进行 *** 作时,要用如下方式打开数据库和 *** 作:
<%
DbPath=ServerMapPath(数据库名)
Set Conn=ServerCreatObject(“ADODBConnection”)
ConnOpen “driver=;dbq=”& DbPath
Sql= *** 作数据库的指令串
ConnExecute sql
… …
%>
四、使用DSN连接数据库
在以上连接数据库的方式中,都是在程序中指定数据库,指定ODBC驱动程序。如果数据源有变化,就需要修改程序。如果在系统级别上,预先定义好数据源DSN,就可以避免这个麻烦。
在定义DSN的过程中,就已经指定好了数据源需要的ODBC驱动程序,也指定好了数据库文件的实际路径和名字,我们在程序中,只需要引用预先定义的数据源名DSN即可。
设定义好的DSN为test,则打开数据库的方式为:
五、结束语
在ASP程序中,建立数据库的连接和访问数据库,有很多方式和技术细节,在此难以一一详述。实际上,对SQL Server数据库,DBF数据库,文本文件,电子表格文件等,也都可以很方便的打开和访问,与对Access数据库的访问大同小异而已。如果说方便,Access应该是首选。如果考虑安全保密性,SQL数据库更好些。使用系统数据源DSN的方式建立对数据库的连接,具有更大的灵活性,也更简便些。
1、加载驱动程序。
2、创建连接对象。
3、创建sql语句执行对象 。
4、执行sql语句。
5、对执行结果进行处理。
6、关闭相关的连接对象即可(顺序跟声明的顺序相反)。
处理结果两种情况:
1、执行更新返回的是本次 *** 作影响到的记录数。
2、执行查询返回的结果是一个ResultSet对象。
ResultSet包含符合SQL语句中条件的所有行,并且它通过一套get方法提供了对这些 行中数据的访问。
扩展资料:
Statement
要执行SQL语句,必须获得javasqlStatement实例,Statement实例分为以下3 种类型:
1、执行静态SQL语句。通常通过Statement实例实现。
2、执行动态SQL语句。通常通过PreparedStatement实例实现。
3、执行数据库存储过程。通常通过CallableStatement实例实现。
参考资料:
最简单的方法就是,使用强数据集。
在添加新项里面,选择数据集。提示输入名称的时候,请你记住这个名称,因为这个就是你要调用的类名了。(如果输入名称是 DataSet1,那命名空间就是DataSet1TableAdapters )
然后就在服务器资源管理器里,按提示新建数据库连接(几乎傻瓜 *** 作)。IDE会自动生成,你需要用到的几乎所有参数。然后找到相应的一个或者几个表,如果表之间有关系,会自动生成关系。然后基本可以说成功了。
使用的话,只用实例化,然后使用类中已经声明好的Fill()方法,传入需要填充的DataSet 的子表。然后就会自动填充数据了。
protected DataSet1 dts = new DataSet1();
protected DataSet1TableAdaptersemployeeTableAdapter empAdapter = new employeeTableAdapter();
// 给一个名为 GridView1 的GridView 进行数据绑定。
private void Bind()
{
// 使用的是 pubs数据库的employee表
// dts 是上面 DataSet1 的实例,在新建时自动创建了 employee表的映射属性(有employee 的表结构)。
thisempAdapterFill( dtsemployee );
thisGridView1DataSource = thisdts;
thisGridView1DataMember = thisdtsemployeeTableName;
thisGridView1DataBind();
}
获得DataSet 了基本所有的 *** 作可以完成了。关于DataSet 的 *** 作,如果要继续写明天都说不完。建议如果楼主,不了解DataSet 的话只有自己多学习了。这里使用最简单的方法来获取,数据库中的表结构、表数据和表关系。
PS: 生成的数据集 DataSet1 类和employeeTableAdapter类同在一个文件中,生成的代码是开放源码的。大家可以追踪引用来学习。
在以前不论是使用SQLyog MySQL GUI或是phpMyAdmin访问数据库,第一步一定是输入访问数据库的账号与密码,当然Dreamweaver也不例外。在Dreamweaver中,我们通过建立 MySQL联机告诉Dreamweaver连接的MySQL数据库地址、名称,以及访问的账号和密码。
在一个网站中,我们只需对一个数据库建立一次MySQL连接。通常网络上的主机空间也只支持访问一个数据库。例如虚拟主机,最基本的方案是搭配1个MySQL数据库。
在文件面板中打开indexphp,接着选择应用程序→数据库面板,单击+按钮后选择MySQL连接。
建立MYSQL连接
在建立数据库连接前,我们必须设置好图6-5中的前面3个选项,如果依照书中叙述设置好,那么基本上便不会有问题。当然必须至少打开一个网页,否则会有无法选择的情况发生。
未打开页面,选项均无法选择
d出如图6-7所示的窗口,请依照其下面的说明进行设置。可以单击测试按钮测试是否有问题,单击确定按钮后就可以在应用程序→数据库面板中看到所建立的数据库连接。我们可以 *** 作这个树状结构(见图6-8)检查连接的数据库、数据表与字段名称及属性等。也可以打开phpMyAdmin来检查数据库结构,并与面板内的信息对比。字段与功能说明。
建立连接
数据库内的数据表、字段和属性
字段与功能说明
字 段
说 明
连接名称
依个人喜好自由输入
MySQL服务器
MySQL服务器的位置,一般设置为localhost,除非所要存取的MySQL数据库不在网页所在的主机上,而且该MySQL数据库也提供对外的连接
用户名
访问MySQL数据库的用户名称
密码
访问MySQL数据库的用户密码
数据库
选择所要建立连接的数据库名称,可以单击选取按钮浏览MySQL服务器上的所有数据库。我们选择刚导入的范例数据库database
在建立完成MySQL连接后,在文件面板中会看到Dreamwaver自动建立了Connections文件夹,在该文件夹下有一个与前面所建立的MySQL连接名称相同的文件。
Connections文件夹
Connections文件夹是Dreamweaver用来存放MySQL连接设置文件的文件夹。
打开该文件并使用代码视图,可以看到有关连接数据库的设置。
数据库连接设置
在这个文件中定义了与MySQL服务器的连接(mysql_pconnect函数),包括以下内容。
$hostname:MySQL服务器的地址。
$database:连接数据库的名称。
$username:用户名称。
$password:用户密码。
定义的值与我们前面在图形界面所设置的值是对应的,然后利用函数mysql_pconnect与数据库连接。连接后才能对数据库进行查询、新增、修改或删除的 *** 作。
如果在网站制作完成后将文件上传至网络上的主机空间时发现,网络上的MySQL服务器访问的用户名、密码等方面与本机设置有所不同,可以直接修改位于Connection文件夹下的db_connphp文件。但还是建议直接在本机配合网络主机上的环境来设置。例如,你拥有虚拟主机所提供的MySQL数据库名称为xu354jp6,但在本机却要命名为Charles,虽然可能会好看些,但到时候就会多一个麻烦了。
对于如何将本机已经完成的网站移植到网络上的空间,将在附录中有详细的介绍。
总之,在建立好数据库连接后,除非要连接MySQL数据库里的另一个数据库,否则不需要再做这个步骤了。
以上就是关于WPS 表格如何连接MySQL 数据库全部的内容,包括:WPS 表格如何连接MySQL 数据库、sql中如何实现级联表的 *** 作(数据库级联怎么实现)、数据库连接方式有哪些等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)