flash与数据库的连接

时间:2022-10-21 11:44:36 作者:只会吃饭 综合材料 收藏本文 下载本文

“只会吃饭”通过精心收集,向本站投稿了10篇flash与数据库的连接,以下是小编整理后的flash与数据库的连接,仅供参考,希望能够帮助到大家。

篇1:flash与数据库的连接

数据|数据库

确切地说..flash是不可以直接与数据库连接的.只能是通过ASP(只是我比较了解ASP,也可以是其他的PHP/JSP等);

所以呢.首先,先在ASP里编写好连接数据库的语句

<%

dim cn

dim connstr

dim db

db=“asp.mdb”

Set cn = Server.CreateObject(“ADODB.Connection”)

connstr=“Provider=Microsoft.Jet.OLEDB.4.0;Data Source=” & Server.MapPath(“”&db&“”)

cn.Open connstr

%>

存储为cn.asp文件;

第二步;就编写一个读取数据库数据的ASP文件喽...

<%

set rs=server.createobject(“adodb.recordset”)

rs.open “select * from class ”,cn,3,3

for i=1 to rs.recordcount

if not rs.eof then

totalClass=totalClass&rs(“Class”)&“,”

totalLink=totalLink&rs(“classlink”)&“,”

rs.movenext

end if

next

response.write (“flashClass=”&totalClass&“&”)

response.write (“flashLink=”&totalLink&“&”)

’注意这个写格式.多个参数得用&这个来连接.有些人会忽略到这一点.导致在flash不能写出数据来.

%>

将这个文件存储为:write.asp

第三步;回到flash那里来编写语句.把write.asp文件加载进来.

第一帧:

System.useCodepage=true;

var newload = new LoadVars();//如果不是很了解这个LoaVars,可以去查一下那个flash里面的帮助文档

newload.load(“write.asp”);

newload.onLoad = function(success) {

if (success) {

_root.gotoAndStop(2);//当文件被加载完成后,执行第二帧.

}

};

stop();//这里要注意.如果不用停止.假设文件还没有加载完就执行第二帧...而在第二帧是在flash里读取数据的.那就导致读不出数据

第二帧:

_root.name.text = newload.flashClass;//下面两句是读取数据的.

_root.link.text = newload.flashLink;

_root.bt._visible = false;//是一个影片的名字,里面放有一个动态文本bttext

//现在就把数据放到数组中去....

var aspclass = newload.flashClass;

var link = newload.flashLink;

var Aclass = new Array();

var Blink = new Array();

for (i=0; i

Aclass = aspclass.split(“,”, i);

Blink = link.split(“,”, i);

}

for (i=0; i

//for (i=1; i<6; i++) {

_root.bt.duplicateMovieClip(“bt”+i, i);

_root[“bt”+i]._y = i*30;

_root[“bt”+i]._x = 5;

_root[“bt”+i].url = Blink;

_root[“bt”+i].bttext.text = Aclass;

_root[“bt”+i].onRelease = function() {

_root.link2.text = this.url;

getURL(“”+this.url,“_blank”);

};

}

篇2:推荐:在Flash中实现与数据库的连接

数据|数据库

一、引言

在动态网页设计中,ASP与Flash技术得到了广泛的应用,ASP具有强大的数据库处理功能,Flash能够实现交互性矢量动画,将Flash与ASP相结合,实现Flash与数据库的连接。

Flash是MacroMedia公司专为网络应用设计的一个交互性矢量动画设计软件。网站设计者可以使用Flash为网站设计各种动态Logo动画、导航条以及全屏动画,还可以加入动感音乐,完全具备多媒体的各项功能。Flash以其体积短小,流体播放的特点迅速打开市场,将WWW上的站点页面设计带上了一个全新的高度。

实现Web数据库的应用一般有两种方法:一种是Web服务器端提供中间件,连接Web服务器与数据库服务器;另一种是把应用程序下载到客户端直接访问数据库。最常用的中间件技术有通用网关接口(CGI)和应用程序编程接口(API)两种。CGI程序存在效率低、速度慢等缺点;而API很大程度上克服了CGI的缺点,但其兼容性差,开发难度大也让许多开发人员望而却步。客户端访问数据库主要包括JavaScript和数据库连接器(IDC)等。用JavaScript和IDC开发Web数据库虽然简单,但也存在功能有限、不能完全控制其过程等缺点,所以它们也无法胜任较复杂的Web数据库的开发。微软推出的ASP方案很好地解决了这些难题。

ASP(Active Server Page)是Microsoft公司推出的一种基于服务器端的脚本编程语言,它很容易和数据库连接。Flash与ASP的组合使网页功能更加强大,可以通过它们和数据库连接,能使我们的网站不仅具有强大的数据支持而且具有完美的交互界面。

为了实现Flash与数据库的连接,需要把Flash和ASP联系起来。

变量可以通过URL传递给Flash,这是一种GET方法,把变量传递给一个swf文件的具体实现是:

接着文本“Text of my variable”将会出现在Flash的动画中指定的位置,我们只要把Flash所需要的数据准备好就可以实现与数据库的连接,然后利用Flash中的动画功能就可以做出既具有强大的数据处理能力又具有强大的交互能力的美观网页。

ASP和数据库的连接可用如下语句实现。

Set Connection = Server.CreateObject(“ADODB.Connection”)Set Recordset = Server.CreateObject(“ADODB.Recordset”)Connection.Open “people”

这样数据库就和ASP连接上,从而 Flash与数据库连接上去了。

在Flash中使用ASP必须满足以下条件:服务器端server必须支持Active Server Pages并且支持数据库;客户端必须安装Flash插件。

二、在Flash中使用数据库

第一步要做的是建立数据库。我们使用Access数据库为例,表名为Staff,有三个字段:ID (自动编号), Known(Text) ,name (Text) 。这是一个用来示范用户名的数据库,

第二步就是建立一个Flash 5的动画。步骤如下:

(1) 建立三个text field.它们是用来显示数据用的。

(2) 把第一个text field的name设置为Input,它是用来接收输入数据的。

(3) 另外两个text field分别命名为KnownAs和Surname。

(4) 其它设置先为默认。

(5) 最后,从Flash的library中选择增加一个按钮 (应该是一个可重用的组件 ScrollBarButton ) 。这是很重要的一步,按钮将把输入的变量传递给ASP页面。到按钮的属性(Properties)上单击Action页,单击“+”号和On MouseEvent.勾上Release框。

(6) 再次单击“+”号和Load/Unload Movie.选择“Load Variables Into Location”在URL输入框内输入你的ASP文件名(例如flash.asp). 选择Target。

(7) 最后,选择Variables中的Send using POST, 单击“+”号来设置变量在Variable输入框内输入“Input”(就是第一个text field的name) 。当上面的工作都完成后,可以在action box内看到如下内容:

On (Release)Load Variables (“flash.asp”, “”, vars=POST)Set Variable: “Input” = “” End On

这样当在动画过程中这个按钮被点击并释放后,Input输入框中的内容将被传递给flash.asp文件。注意Form是使用的post方式传递变量的。

(8) 建立一个HTML页面,在其中包含这个Flash动画文件。

第三步:ASP文件的代码

<% Set Connection = Server.CreateObject(“ADODB.Connection”) Set Recordset = Server.CreateObject(“ADODB.Recordset”) Connection.Open “people”   SQL = “SELECT * FROM Staff  WHERE ID=” & Request.Form(“Input”) & “;” Recordset.Open SQL,Connection,1,2 If Recordset.EOF Then KnownAs = “Not” Surname = “Found” Else KnownAs = Recordset (“Known”) Surname = Recordset (“name”)End IfRecordset.CloseConnection.Closeresponse.write(“KnownAs=”+Server.URLEncode(KnownAs))response.write(“&Surname=”+Server.URLEncode(Surname))%>

需要注意的是在把KnownAs和Surname传递回去的写法,将是这样的Known=Data1&Surname=Data2。使用Server.URLEncode(VariableName)来保证传递过去变量的是按照 URL格式编码的。

篇3:VB6.0与SQLServer――有源数据库连接

VB6.0中数据访问接口有三种:ActiveX数据库对象(ADO)、远程数据对象(RDO)和数据访问对象(DAO),ADO(ActiveX Data Objects)是用于存取数据源的COM组件是Microsoft数据库应用程序开发的接口,是建立在OLEDB之上的高层数据库访问技术。它封装了OLEDB所提供的接口,比起OLEDB的提供者,ADO接口可以使程序员在更高级别上进行数据交互。它提供了统一数据库访问方式OLEDB(Object Linking and Embedding Database)的一个中间层。VB6.0与SQL Server建立连接有两种方法:有源数据库连接和无源数据库连接,区别他们看是否使用了DSN连接。无源数据库连接是不需要配置ODBC数据源,利用ADO就可以通过代码编写的。

下面主要介绍一下有源数据库连接。首先要注册数据源名称(DSN),通过配置ODBC环境进行数据源注册。

数据源分三类:

(1)用户DSN:只有创建数据源的用户才可以使用他们自己创建的数据源而且只能在当前计算机上使用。

(2)系统DSN:任何使用计算机的用户和程序都可以使用,

(3)文件DSN:除了具有系统DSN的功能外,还能被其他用户在其他计算机上使用。

首先,我们选择创建文件DSN,并单击添加。

www.2cto.com

其次,在创建新数据源中选择SQL Server驱动程序。

第三步,输入想要保存此链接的文件数据源的名称。

第四步,选择服务器

然后,设置登录认证

如下选项可以根据需要选择

最后,进行测试数据源。

显示成功,点击确定,文件DSN设置成功!

ODBC(Open Database Connectivity)开放数据库互联,是一种接口规范。利用ODBC可以在应用程序中同时访问多个数据库系统,ODBC最大优点是能以统一的方式处理所有的数据库。

作者 康立贤

篇4:PB如何连接Oracle数据库

如果你已经是个powerbuilder高手,那么下面的东西对你来说毫无价值,你大可不必再看下去,如果你刚刚步入powerbuilder的殿堂,那么下面的东西对你来说可能有点价值,你应该看一看。

作为一个优秀的客户端开发工具,powerbuilder必然需要与大型的数据库相连接,尽管许多资料上都介绍了如何通过odbc或者powerbuilder自带的db profile或者专用接口连接上数据库,但仍然有许多使用者按此方法却无法连接上数据库,这方面的原因可能是powerbuilder本身的原因,比如在安装powerbuilder时的选项、odbc的版本之类;也可能是在安装客户端的oracle、sybase、informix、sql server等软件上的问题,下面就从最根本的odbc配置开始,教你一步步如何连接上数据库。 odbc数据源的配置

进入控制面板,打开odbc数据源(32位),如图1所示,点击“add”按钮,进入odbc数据源的配置面板,如图2所示:

选择“oracle odbc driver”一项,注意当前版本号为“8.00.0400”,如果你的操作系统中安装的是oracle7,则相应的版本号会不同。提醒一点:在windows98操作系统上是无法安装oracle8.0.4的(只能安装oracle7.2.3),oracle8.0.5则没有试过。因而会有一些使用者在windows98系统上无法正常配置odbc数据源,因为windows98本身自带的odbc数据源已经比oracle7数据源版本要高,无论你怎样配置odbc,系统总会提示你要安装一个更高版本的oracle,自然你就无法配置odbc了,有一个解决方法就是用pb7第二张光盘上的odbc安装程序覆盖系统中的odbc,或者把你的操作系统改为windows95/97算了。

然后进入“oracle8 odbc driver setup”设置,在“data source name”一项中随便输入一个名字,在“data source service name”一栏中输入oracle连接数据库的字符串名,这可以在你安装的oracle目录中的tnsnames.ora文件中查看到(oracle7安装路径为“orawin95network admin”;oracle8安装路径为“orawin95net80admin”),或者你通过“sql net easy configuration”新添加一个数据库连接配置,将配置中的字符串填入即可,其他的就不必再填入,避免出现画蛇添足之错,反而连接不上数据库了。 db profile数据源的配置

进入pb,打开db profile,如图4所示,选择odbc一项,点击“new”,进入pb数据源的配置,如图5所示。当然如果你之前没有进行odbc的配置,你也可以在这里点击“config odbc”进入之前你看到的odbc配置界面。

在“profile name”中自定义一个名字,然后从“data source”的下拉菜单中选择你在odbc中已经配置好的数据源,输入登录数据库所需要的用户名与密码,当然你认为没有这个必要性的话可以不在这里输入(主要是不要轻易让人知道你数据库的口令,不然问题就大了),到这一步为止,pb已经做完了所有数据库连接的配置,剩下的就是连接上数据库了。 pb for oracle专用接口的配置

同样是进入pb,点击db profile选项(这是对oracle7版本而言,如果是oracle8,相应的选项就是oracle8.0.4),看到上面的“073 oracle 7.3”选项没有,点击一下,再按“new”进入图7的界面,“profile name”一栏随意填,“server”一栏填写时要注意,oracle7版本一定要在数据连接字符串前加上@,否则不能连接上pb数据库,oracle8版本则不必加上@,其他的设置就可以不用了。

以上三种pb连接数据库的方法其实十分简单,但是初学者却又会经常出错,在这里只是想作为一种抛砖引玉之用,希望广大初学者通过本文对pb数据源配置能够有一定的了解。下面再对oracle连接数据库的配置文件tnsnames.ora简单说明一下,“tnsnames.ora”文件其实是通过“sql net easy configuration”初始化配置后的参数文件,如果你不想通过“sql net easy configuration”进行配置,你只需要把你先前已有的“tnsnames.ora”文件放入oracle的admin目录中,覆盖现有的文件就可以了,当然你也可以再自己添加数据库连接字符串。通常,一个“tnsnames.ora”文件内容如下: ······kf.world = (description = (address_list =(address =(community = tcp.world) (protocol = tcp) (host = 136.12.145.5) (port = 1521) ) (address =(community = tcp.world) (protocol = tcp) (host = 136.12.145.5) (port = 1526) ) ) (connect_data = (sid = sid3) ) )······

其中最要的是第一项和最后一项(这里是以tcp/ip网络连接,大多数用户都是以此连接),host一栏是主机地址,“connect_data = (sid = sid3)”中的sid3是连接主机数据库的字符串,你要修改这几项就可以了。另外谈谈如何让英文版的oracle7显示中文,其实很简单,只要将注册表“hkey_local_machine softwareoraclenls_lang”中的值改为如下值就可以了“ simplified chinese_china.zhs16cgb231280”。

篇5:python mysqldb连接数据库

-07-07python之import机制详解

-09-09python encode和decode的妙用

2009-02-02wxpython 学习笔记 第一天

-06-06Python查询Mysql时返回字典结构的代码

2014-07-07Python中的二叉树查找算法模块使用指南

2014-04-04python处理圆角图片、圆形图片的例子

2014-01-01pyside写ui界面入门示例

-03-03Python中删除文件的程序代码

2014-06-06Python实现多线程下载文件的代码实例

-12-12pymssql ntext字段调用问题解决方法

篇6:python mysqldb连接数据库

最近更 新

python模块restful使用方法实例

Python Web框架Pylons中使用MongoDB的例子

python多线程抓取天涯帖子内容示例

python使用scrapy解析js示例

python二叉树遍历的实现方法

Python3.x和Python2.x的区别介绍

python 实现文件的递归拷贝实现代码

python使用paramiko模块实现ssh远程登陆上

Python实现的百度站长自动URL提交小工具

Python转码问题的解决方法

热 点 排 行

Python入门教程 超详细1小时学会

python 中文乱码问题深入分析

比较详细Python正则表达式操作指

Python字符串的encode与decode研

Python open读写文件实现脚本

Python enumerate遍历数组示例应

Python 深入理解yield

Python+Django在windows下的开发

python 字符串split的用法分享

python 文件和路径操作函数小结

篇7:MFC连接SQLServer数据库

其步骤一般分为:

(1) 引入ADO动态库文件

(2) 初始化COM环境

(3) 连接数据库操作数据表

说明:本数据库使用SQLServer2005制作,名字为“student”,内含一个表,命名为“stud”。

建表语句

create table stud

(

num varchar(7),

name nvarchar(20) not null,

gender nchar(2) default '男' check(gender in('男','女')),

dept nvarchar(20) not null

)

插入一些数据

insert into stud values('0147256','test','男','计算机系');

进行疯狂复制,多添加一些数据

insert into stud select * from stud;

本例中创建的数据源名字为'test'

需要添加数据源

在stdafx.h添加以下代码引入ADO动态库文件

#import “C:Program FilesCommonFilesSystemadomsado15.dll” no_namespacerename(“EOF”,“adoEOF”)rename(“BOF”,“adoBOF”)

初始化COM环境

::CoInitialize(NULL); //在app类中的InitInstance函数中添加

::CoUninitialize; //在app类中的InitInstance函数的最后(return之前)添加,释放COM环境

首先先在dlg头文件中先声明这两个智能指针,通过这些指针可以很容易的创建和删除ADO对象。

_ConnectionPtrm_pConnection;

_RecordsetPtrm_pRecordset;

接下来在dlg类中添加函数void OnInitADOConn()

void CMy1Dlg::OnInitADOConn()

{

::CoInitialize(NULL); //初始化COM环境

try

{

//创建连接对象实例

m_pConnection.CreateInstance(“ADODB.Connection”);

CString strConnect;

//注意,我这里写的连接字符串是通过以下步骤的得到的:

//1、新建一个文件,名字任意取,后缀名必须为udl(如何hello.udl)

//2、双击hello.udl文件,进入数据连接属性面板,填写好数据源(选择自己创建的数据源名字的)

//3、再以记事本方式打开,第三行的数据就是连接字符

strConnect=“Provider=MSDASQL.1;Persist Security Info=False;User ID=sa;Data Source=test;Password=*******”;

//使用Open方法连接数据库

m_pConnection->Open((_bstr_t)strConnect,“”,“”,adModeUnknown);

}

catch(_com_error e)

{

AfxMessageBox(e.Description());

}

}

在dlg类中在添加void ExitConnect()函数

void CMy1Dlg::ExitConnect()

{

//关闭记录集和连接

if(m_pRecordset!=NULL)

m_pRecordset->Close();

m_pConnection->Close();

}

在dlg类的OnInitDialog函数中添加如下代码,设置列表视图的风格和标题(写在最后)

m_Grid.SetExtendedStyle(LVS_EX_FLATSB

|LVS_EX_FULLROWSELECT

|LVS_EX_HEADERDRAGDROP

|LVS_EX_ONECLICKACTIVATE

|LVS_EX_GRIDLINES);

m_Grid.InsertColumn(0,“编号”,LVCFMT_LEFT,110,0);

m_Grid.InsertColumn(1,“姓名”,LVCFMT_LEFT,110,1);

m_Grid.InsertColumn(2,“性别”,LVCFMT_LEFT,110,2);

m_Grid.InsertColumn(3,“学历”,LVCFMT_LEFT,110,3);

AddToGrid();

在dlg类中添加void AddToGrid()函数

void CMy1Dlg::AddToGrid()

{

//连接数据库

OnInitADOConn();

//设置查询字符串

_bstr_tbstrSQL = “select * from stud”;

//创建记录集指针对象实例

m_pRecordset.CreateInstance(__uuidof(Recordset));

//打开记录集

m_pRecordset->Open(bstrSQL,m_pConnection.GetInterfacePtr(),adOpenDynamic,

adLockOptimistic,adCmdText);

int i=0;

while(!m_pRecordset->adoEOF)

{

m_Grid.InsertItem(i,“”);

m_Grid.SetItemText(i,0,(char*)(_bstr_t)m_pRecordset->GetCollect(“num”));

m_Grid.SetItemText(i,1,(char*)(_bstr_t)m_pRecordset->GetCollect(“sex”));

m_Grid.SetItemText(i,2,(char*)(_bstr_t)m_pRecordset->GetCollect(“gender”));

m_Grid.SetItemText(i,3,(char*)(_bstr_t)m_pRecordset->GetCollect(“dept”));

//两种方式均可

/*

m_Grid.SetItemText(i,0,(_bstr_t)m_pRecordset->GetCollect(_variant_t((long)0)));

m_Grid.SetItemText(i,1,(_bstr_t)m_pRecordset->GetCollect(_variant_t((long)1)));

m_Grid.SetItemText(i,2,(_bstr_t)m_pRecordset->GetCollect(_variant_t((long)2)));

m_Grid.SetItemText(i,3,(_bstr_t)m_pRecordset->GetCollect(_variant_t((long)3)));

*/

i++;

//将记录集指针移动到下一条记录

m_pRecordset->MoveNext();

}

//断开数据库连接

ExitConnect();

}

接下来为四个edit控件和一个list constrol控件关联变量,在资源中右键点击选择classwizar里的Member variables,分别为它们设置变量为m_ID,m_Name,m_Sex,m_Culture,m_Grid.在dlg类的头文件部分自动会生成

CString m_ID;

CString m_Name;

CString m_Sex;

CString m_Culture;

CListCtrl m_Grid;

Dlg类构造函数中

m_ID = _T(“”);

m_Name = _T(“”);

篇8:的数据库连接程序

我从来就不用DNS连接,我觉得那个很不方便,下面这部分程序可说是万能的数据库连接程序几乎可以连接所有的MS数据库,自己拿去研究吧(这个程序是“ASP网页制作教程”这本书里面的――一本好书):

<%

'---------------------------------------------------

Function GetMdbConnection( FileName )

Dim Provider, DBPath Provider = “Provider=Microsoft.Jet.OLEDB.4.0;”

DBPath = “Data Source=” & Server.MapPath(FileName)

Set GetMdbConnection = GetConnection( Provider & DBPath )

End Function '---------------------------------------------------

Function GetSecuredMdbConnection( FileName, Password )

Dim Provider, DBPath Provider = “Provider=Microsoft.Jet.OLEDB.4.0;”

DBPath = “Data Source=” & Server.MapPath(FileName)

Set GetSecuredMdbConnection = GetConnection( Provider & DBPath & “;Jet OLEDB:Database Password=” & Password )

End Function '---------------------------------------------------

Function GetDbcConnection( FileName )

Dim Driver, SourceType, DBPath Driver = “Driver={Microsoft Visual FoxPro Driver};”

SourceType = “SourceType=DBC;”

DBPath = “SourceDB=” & Server.MapPath( FileName )

Set GetDbcConnection = GetConnection( Driver & SourceType & DBPath )

End Function '---------------------------------------------------

Function GetDbfConnection( Directory )

Dim Driver, SourceType, DBPath Driver = “Driver={Microsoft Visual FoxPro Driver};”

SourceType = “SourceType=DBF;”

DBPath = “SourceDB=” & Server.MapPath( Directory )

Set GetDbfConnection = GetConnection( Driver & SourceType & DBPath )

End Function '---------------------------------------------------

Function GetExcelConnection( FileName )

Dim Driver, DBPath Driver = “Driver={Microsoft Excel Driver (*.xls)};”

DBPath = “DBQ=” & Server.MapPath( FileName )

Set GetExcelConnection = GetConnection( Driver & “ReadOnly=0;” & DBPath )

End Function '---------------------------------------------------

Function GetTextConnection( Directory )

Dim Driver, DBPath Driver = “Driver={Microsoft Text Driver (*.txt; *.csv)};”

DBPath = “DBQ=” & Server.MapPath( Directory )

Set GetTextConnection = GetConnection( Driver & DBPath )

End Function '---------------------------------------------------

Function GetSQLServerConnection( Computer, UserID, Password, Db )

Dim Params, conn Set GetSQLServerConnection = Nothing

Params = “Provider=SQLOLEDB.1”

Params = Params & “;Data Source=” & Computer

Params = Params & “;User ID=” & UserID

Params = Params & “;Password=” & Password

Params = Params & “;Initial Catalog=” & Db

Set conn = Server.CreateObject(“ADODB.Connection”)

conn.Open Params

Set GetSQLServerConnection = conn

End Function '---------------------------------------------------

Function GetMdbRecordset( FileName, Source )

Set GetMdbRecordset = GetMdbRs( FileName, Source, 2, “” )

End Function '---------------------------------------------------

Function GetMdbStaticRecordset( FileName, Source )

Set GetMdbStaticRecordset = GetMdbRs( FileName, Source, 3, “” )

End Function '---------------------------------------------------

Function GetSecuredMdbRecordset( FileName, Source, Password )

Set GetSecuredMdbRecordset = GetMdbRs( FileName, Source, 2, Password )

End Function '---------------------------------------------------

Function GetSecuredMdbStaticRecordset( FileName, Source, Password )

Set GetSecuredMdbStaticRecordset = GetMdbRs( FileName, Source, 3, Password )

End Function '---------------------------------------------------

Function GetDbfRecordset( Directory, SQL )

Set GetDbfRecordset = GetOtherRs( “Dbf”, Directory, SQL, 2 )

End Function '---------------------------------------------------

Function GetDbfStaticRecordset( Directory, SQL )

Set GetDbfStaticRecordset = GetOtherRs( “Dbf”, Directory, SQL, 3 )

End Function '---------------------------------------------------

Function GetDbcRecordset( FileName, SQL )

Set GetDbcRecordset = GetOtherRs( “Dbc”, FileName, SQL, 2 )

End Function '---------------------------------------------------

Function GetDbcStaticRecordset( FileName, SQL )

Set GetDbcStaticRecordset = GetOtherRs( “Dbc”, FileName, SQL, 3 )

End Function '---------------------------------------------------

Function GetExcelRecordset( FileName, SQL )

Set GetExcelRecordset = GetOtherRs( “Excel”, FileName, SQL, 2 )

End Function '---------------------------------------------------

Function GetExcelStaticRecordset( FileName, SQL )

Set GetExcelStaticRecordset = GetOtherRs( “Excel”, FileName, SQL, 3 )

End Function '---------------------------------------------------

Function GetTextRecordset( Directory, SQL )

Set GetTextRecordset = GetOtherRs( “Text”, Directory, SQL, 2 )

End Function '---------------------------------------------------

Function GetTextStaticRecordset( Directory, SQL )

Set GetTextStaticRecordset = GetOtherRs( “Text”, Directory, SQL, 3 )

End Function '---------------------------------------------------

Function GetSQLServerRecordset( conn, source )

Dim rs Set rs = Server.CreateObject(“ADODB.Recordset”)

rs.Open source, conn, 2, 2

Set GetSQLServerRecordset = rs

End Function '---------------------------------------------------

Function GetSQLServerStaticRecordset( conn, source )

Dim rs Set rs = Server.CreateObject(“ADODB.Recordset”)

rs.Open source, conn, 3, 2

Set GetSQLServerStaticRecordset = rs

End Function '---------------------------------------------------

Function GetConnection( Param )

Dim conn On Error Resume Next

Set GetConnection = Nothing

Set conn = Server.CreateObject(“ADODB.Connection”)

If Err.Number 0 Then Exit Function conn.Open Param

If Err.Number 0 Then Exit Function

Set GetConnection = conn

End Function '---------------------------------------------------

Function GetMdbRs( FileName, Source, Cursor, Password )

Dim conn, rs On Error Resume Next

Set GetMdbRs = Nothing

If Len(Password) = 0 Then

Set conn = GetMdbConnection( FileName )

Else

Set conn = GetSecuredMdbConnection( FileName, Password )

End If

If conn Is Nothing Then Exit Function Set rs = Server.CreateObject(“ADODB.Recordset”)

If Err.Number 0 Then Exit Function rs.Open source, conn, Cursor, 2

If Err.Number 0 Then Exit Function

Set GetMdbRs = rs

End Function '---------------------------------------------------

Function GetOtherRs( DataType, Path, SQL, Cursor )

Dim conn, rs

On Error Resume Next

Set GetOtherRs = Nothing Select Case DataType

Case “Dbf”

Set conn = GetDbfConnection( Path )

Case “Dbc”

Set conn = GetDbcConnection( Path )

Case “Excel”

Set conn = GetExcelConnection( Path )

Case “Text”

Set conn = GetTextConnection( Path )

End Select

If conn Is Nothing Then Exit Function Set rs = Server.CreateObject(“ADODB.Recordset”)

If Err.Number 0 Then Exit Function rs.Open SQL, conn, Cursor, 2

If Err.Number 0 Then Exit Function

Set GetOtherRs = rs

End Function '---------------------------------------------------

Function GetSQLServerRs( Computer, UserID, Password, Db, source, Cursor )

Dim conn, rs On Error Resume Next

Set GetSQLServerRs = Nothing

Set conn = GetSQLServerConnection( Computer, UserID, Password, Db )

If conn Is Nothing Then Exit Function Set rs = Server.CreateObject(“ADODB.Recordset”)

If Err.Number 0 Then Exit Function rs.Open source, conn, Cursor, 2

If Err.Number 0 Then Exit Function

Set GetSQLServerRs = rs

End Function

%>

使用方法是――复制下来存成一个文件,然后用#Include “文件名”就可以调用里面的子程序了,

万能的数据库连接程序

有什么问题可以一起探讨!!!

篇9:连接各种数据库方式速查表

连接各种数据库方式速查表

1、Oracle8/8i/9i数据库(thin模式)

Class.forName(“oracle.jdbc.driver.OracleDriver”);

String url=“jdbc:oracle:thin:@localhost:1521:orcl”;

//orcl为数据库的SID

String user=“test”;

String password=“test”;

Connection conn= DriverManager.getConnection(url,user,password);

2、DB2数据库

Class.forName(“com.ibm.db2.jdbc.app.DB2Driver ”).newInstance;

String url=“jdbc:db2://localhost:5000/sample”;

//sample为你的数据库名

String user=“admin”;

String password=“”;

Connection conn= DriverManager.getConnection(url,user,password);

3、Sql Server7.0/数据库

Class.forName(“com.microsoft.jdbc.sqlserver.SQLServerDriver”).newInstance();

String url=“jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=mydb”;

//mydb为数据库

String user=“sa”;

String password=“”;

Connection conn= DriverManager.getConnection(url,user,password);

4、Sybase数据库

Class.forName(“com.sybase.jdbc.SybDriver”).newInstance();

String url =“ jdbc:sybase:Tds:localhost:5007/myDB”;

//myDB为你的数据库名

Properties sysProps = System.getProperties();

SysProps.put(“user”,“userid”);

SysProps.put(“password”,“user_password”);

Connection conn= DriverManager.getConnection(url, SysProps);

5、Informix数据库

Class.forName(“com.informix.jdbc.IfxDriver”).newInstance();

String url =

“jdbc:informix-sqli://123.45.67.89:1533/myDB:INFORMIXSERVER=myserver;

user=testuser;password=testpassword”;

//myDB为数据库名

Connection conn= DriverManager.getConnection(url);

6、MySQL数据库

Class.forName(“org.gjt.mm.mysql.Driver”).newInstance();

String url =“jdbc:mysql://localhost/myDB?

user=soft&password=soft1234&useUnicode=true&characterEncoding=8859_1”

//myDB为数据库名

//使用MySQL数据库驱动

MySQLDB

jdbc:mysql://localhost:3306/dbname

com.mysql.jdbc.Driver

user

pass

Connection conn= DriverManager.getConnection(url);

7、PostgreSQL数据库

Class.forName(“org.postgresql.Driver”).newInstance();

String url =“jdbc:postgresql://localhost/myDB”

//myDB为数据库名

String user=“myuser”;

String password=“mypassword”;

Connection conn= DriverManager.getConnection(url,user,password);

1、Oracle8/8i/9i数据库(thin模式)

Class.forName(“oracle.jdbc.driver.OracleDriver”).newInstance();

String url=“jdbc:oracle:thin:@localhost:1521:orcl”;

//orcl为数据库的SID

String user=“test”;

String password=“test”;

Connection conn= DriverManager.getConnection(url,user,password);

2、DB2数据库

Class.forName(“com.ibm.db2.jdbc.app.DB2Driver ”).newInstance();

String url=“jdbc:db2://localhost:5000/sample”;

//sample为你的数据库名

String user=“admin”;

String password=“”;

Connection conn= DriverManager.getConnection(url,user,password);

3、Sql Server7.0/2000数据库

Class.forName(“com.microsoft.jdbc.sqlserver.SQLServerDriver”).newInstance();

String url=“jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=mydb”;

//mydb为数据库

String user=“sa”;

String password=“”;

Connection conn= DriverManager.getConnection(url,user,password);

4、Sybase数据库

Class.forName(“com.sybase.jdbc.SybDriver”).newInstance();

String url =“ jdbc:sybase:Tds:localhost:5007/myDB”;

//myDB为你的数据库名

Properties sysProps = System.getProperties();

SysProps.put(“user”,“userid”);

SysProps.put(“password”,“user_password”);

Connection conn= DriverManager.getConnection(url, SysProps);

5、Informix数据库

Class.forName(“com.informix.jdbc.IfxDriver”).newInstance();

String url =

“jdbc:informix-sqli://123.45.67.89:1533/myDB:INFORMIXSERVER=myserver;

user=testuser;password=testpassword”;

//myDB为数据库名

Connection conn= DriverManager.getConnection(url);

6、MySQL数据库

Class.forName(“org.gjt.mm.mysql.Driver”).newInstance();

String url =“jdbc:mysql://localhost/myDB?user=soft&password=soft1234&useUnicode=true&characterEncoding=8859_1”

//myDB为数据库名

Connection conn= DriverManager.getConnection(url);

7、PostgreSQL数据库

Class.forName(“org.postgresql.Driver”).newInstance();

String url =“jdbc:postgresql://localhost/myDB”

//myDB为数据库名

String user=“myuser”;

String password=“mypassword”;

Connection conn= DriverManager.getConnection(url,user,password);

一、连接各种数据库方式速查表

下面罗列了各种数据库使用JDBC连接的方式,可以作为一个手册使用,

1、Oracle8/8i/9i数据库(thin模式)

Class.forName(“oracle.jdbc.driver.OracleDriver”).newInstance();

String url=“jdbc:oracle:thin:@localhost:1521:orcl”; //orcl为数据库的SID

String user=“test”;

String password=“test”;

Connection conn= DriverManager.getConnection(url,user,password);

2、DB2数据库

Class.forName(“com.ibm.db2.jdbc.app.DB2Driver ”).newInstance();

String url=“jdbc:db2://localhost:5000/sample”; //sample为你的数据库名

String user=“admin”;

String password=“”;

Connection conn= DriverManager.getConnection(url,user,password);

3、Sql Server7.0/2000数据库

Class.forName(“com.microsoft.jdbc.sqlserver.SQLServerDriver”).newInstance();

String url=“jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=mydb”;

//mydb为数据库

String user=“sa”;

String password=“”;

Connection conn= DriverManager.getConnection(url,user,password);

4、Sybase数据库

Class.forName(“com.sybase.jdbc.SybDriver”).newInstance();

String url =“ jdbc:sybase:Tds:localhost:5007/myDB”;//myDB为你的数据库名

Properties sysProps = System.getProperties();

SysProps.put(“user”,“userid”);

SysProps.put(“password”,“user_password”);

Connection conn= DriverManager.getConnection(url, SysProps);

5、Informix数据库

Class.forName(“com.informix.jdbc.IfxDriver”).newInstance();

String url =

“jdbc:informix-sqli://123.45.67.89:1533/myDB:INFORMIXSERVER=myserver;

user=testuser;password=testpassword”; //myDB为数据库名

Connection conn= DriverManager.getConnection(url);

6、MySQL数据库

Class.forName(“org.gjt.mm.mysql.Driver”).newInstance();

String url =“jdbc:mysql://localhost/myDB?user=soft&password=soft1234&useUnicode=true&characterEncoding=8859_1”

//myDB为数据库名

Connection conn= DriverManager.getConnection(url);

7、PostgreSQL数据库

Class.forName(“org.postgresql.Driver”).newInstance();

String url =“jdbc:postgresql://localhost/myDB” //myDB为数据库名

String user=“myuser”;

String password=“mypassword”;

Connection conn= DriverManager.getConnection(url,user,password);

8、access数据库直连用ODBC的

Class.forName(“sun.jdbc.odbc.JdbcOdbcDriver”) ;

String url=“jdbc:odbc:Driver={MicroSoft Access Driver (*.mdb)};DBQ=”+application.getRealPath(“/Data/ReportDemo.mdb”);

Connection conn = DriverManager.getConnection(url,“”,“”);

Statement stmtNew=conn.createStatement() ;

MySQL高级特性----对比与其他数据库

性能

对于速度的真实比较,以及不断成熟的MySQL基准套件。见10.8 使用你自己的基准。因为没有线程创建开销、一个较小的语法分析器、较少功能和简单的安全性,mSQL应该在下列方面更快些:

执行重复的连接和断开的测试,在每个连接期间运行一个非常简单的查询。

有很少的列和键的插入很简单的表的INSERT操作。

CREATE TABLE和DROP TABLE。

在不是一个索引的一些东西上SELECT。(一个表扫描是很容易的。)

因为这些操作是如此简单,当你有更高的启动开销时,很难在这些方面变得更好。在连接被建立以后,MySQL应该性能好一些。在另一方面,MySQL比mSQL(以及大多数其他的SQL实现)在下列方面更好些:

复杂的SELECT操作

检索较大的结果(MySQL有一个更好、更快并且更安全的协议)。

有变长字符串的表,因为MySQL有更有效的并可在VARCHAR列上索引。

有很多列的表的处理。

由长记录的表的处理。

有很多许多表达式的SELECT。

在大表上的SELECT。

同时处理很多连接。MySQL充分是完全多线程化的,每个连接有它自己的线程,这意味着没有线程必须等待另一个线程(除非一个线程正在修改一张表,另外的线程想要存取)在mSQL中,一旦一个连接被建立了,所有其它线程必须等到第一个线程完成,不管连接正在运行的查询是短的或是长的。当第一个连接终止时,下一个才能工作,而此时所有其它线程再次等待,等等。

联结。如果你改变一个SELECT中的表的顺序,mSQL可能变得异常地慢。在基准套件中,比MySQL要慢超过15000倍的时间。这是由于mSQL缺乏一个联结优化器以便以最佳的顺序排定表。然而,如果你把表按完全正确的顺序放在mSQL2中并且WHERE是很简单的并使用索引列,联结将相对快些!见10.8 使用你自己的基准。

ORDER BY和GROUP BY。

DISTINCT。

使用TEXT或BLOB列。

SQL功能

GROUP BY和HAVING。mSQL根本不支持GROUP BY。MySQL支持一个有两个HAVING和下列函数: COUNT()、AVG()、MIN()、MAX()、SUM()和STD()的完整的GROUP BY。如果SELECT从一张表中检索,没有其他列被检索并且没有WHERE子句,COUNT(*)被优化以很快地返回。 MIN()和MAX()可以取字符串参数。

带计算的INSERT和UPDATE。MySQL能在一个INSERT或UPDATE中做计算。例如:

mysql>UPDATE SET x=x*10+y WHERE x<20;

别名,MySQL有列的别名。

限制列名。在MySQL中,如果一个列名在用于查询的表之间唯一的,你不必须使用完整的 合格者。

带函数的SELECT。MySQL有很多函数(太多不能在这里列出;见7.4 用在SELECT和WHERE子句中的函数)。

磁盘空间效率

即,你能使你的表有多小?MySQL有很精确的类型,因此你可以创建占据很小空间的表。一个有用的MySQL数据类型的例子是MEDIUMINT,它是3个字节长。如果你有100,000,000个记录,每个记录节省甚至一个字节也是很重要的。mSQL2有一个较有限的列类型集合,因此更难于使表更小。

稳定性

这较难客观地评价。对于MySQL稳定性的讨论,见1.5 MySQL有多么稳定?。我们没有mSQL稳定性的经验,因此我们对此不能说任何东西。

价格

另一个重要的问题是许可证。MySQL有一个比mSQL更灵活的许可证,并且也不比mSQL昂贵。无论你选择使用哪个产品,记得要至少考虑支付一个许可证或电子邮件支持的费用。(当然如果你把你出售的一个产品包括在MySQL中,你将被要求获得一个许可证。)

Perl接口

MySQL有与mSQL基本相同Perl接口,当有一些增加的功能。

JDBC ( Java )

MySQL目前有4个JDBC驱动程序:

gwe 驱动程序:由GWE technologies 开发的一个Java接口(不再支持)。

jms 驱动程序:由Xiaokun Kelvin ZHU的开发的一个改进的gwe驱动程序。

twz 驱动程序:由Terrence W. Zellers 开发的一个type 4 JDBC驱动程序并用于学习目的。

mm 驱动程序:由Mark Matthews 开发的一个type 4 JDBC驱动程序。

推荐的驱动程序是twz或mm驱动程序。两者均被报导工作出色。我们知道mSQL有一个 JDBC 驱动程序,但是我们对它有太少的经验不能进行比较。

开发速度

MySQL有一个非常小的开发者队伍,但是我们是非常习惯于用C和C++编码,非常快速。因为线程、函数、GROUP BY等在mSQL中仍未实现,它有很多追赶工作要做。要想得到关于它的一些前景,你可以查看mSQL最后一年的 “HISTIRY”文件,并将它与MySQL参考书手册的新功能小节比较(见D MySQL变迁历史)。哪个快开发得最快应该是相当明显的。

实用程序

mSQL和MySQL都有许多有趣的第三方工具。因为向上移植(从mSQL到MySQL)是很容易的,几乎所有mSQL可用的有趣的应用程序也可被MySQL使用。MySQL带有一个简单的msql2mysql程序修正在mSQL和MySQL使用的大多数C API函数之间拼写差别。例如,它将msqlConnect()实例改变为mysql_connect()。变换一个客户程序从mSQL到MySQL通常花几分钟时间。

21.1.1 怎样将mSQL的工具转换到MySQL

根据我们的经验,转换诸如使用mSQL C API的msql-tcl和msqljava工具将只花不大一小时时间,使得他们用MySQL C API工作。

转换过程是:

在源代码上运行外壳脚本msql2mysql。这需要replace程序,它与MySQL一起散发,

编译。

修正所有编译器错误。

mSQL C API与MySQL C API 之间差别是:

MySQL使用一个MYSQL结构作为一种连接类型(mSQL使用一个int)。

mysql_connect()取一个指向一个MYSQL结构的指针作为一个参数。很容易定义全局性定义一个或使用malloc()获得一个。mysql_connect()也取两个参数指定用户和口令。你可以为了缺省使用将这些设置为NULL,NULL。

mysql_error()取MYSQL结构作为一个参数。如果你正在移植老的代码,只是把参数加到你的老的msql_error()编码中。

MySQL对所有错误返回一个错误号和一条文本错误消息。mSQL仅返回一条文字错误消息。

存在某些不兼容性,因为MySQL支持从同一个进程的到服务器多个连接。

mSQL和MySQL的客户机/服务器通讯协议有何不同

有足够的差别使得不可能(或至少不容易)支持两者。

它MySQL协议不同于mSQL协议的最重要的方面列在下面:

一个消息缓冲区可以包含很多结果行。

如果查询或结果比当前缓冲区大,消息缓冲区动态地被扩大,直到一个可配置的服务器和客户上限。

所有的包被编号以捕捉重复或丢失的包。

所有的列值以ASCII码发送。列和行的长度以紧凑的二进制编码(1、2或3个字节)发送。

MySQL能在未缓冲得结果中读取(不必在客户端存储完整的集合)。

如果一个单独写/读花了超过30秒时间,服务器关闭连接。

如果一个连接空闲8个小时,服务器关闭连接。

mSQL 2.0的SQL句法与MySQL有何不同

列类型

MySQL

有下列额外的类型(比较其他的;见7.7 CREATE TABLE句法): 、

对于一个字符串集中之一的ENUM类型。

对于一个字符串集中多个的SET类型。

对于64位整数的BIGINT类型。

MySQL也支持下列额外的类型属性:

UNSIGNED选项。

对于整数列的ZEROFILL选项。

对于是一个PRIMARY KEY的整数列的AUTO_INCREMENT选项。见20.4.29 mysql_insert_id()。

对所有列的DEFAULT值。

mSQL2

mSQL列类型对应于MySQL类型显示在下面:mSQL类型 相应的MySQL类型

CHAR(len) CHAR(len)

TEXT(len) TEXT(len),len是最大长度。并且LIKE可运用。

INT INT,有很多的选项!

REAL REAL,或FLOAT。有4和8字节版本。

UINT INT UNSIGNED

DATE DATE,使用 ANSI SQL 格式而非mSQL自己的。

TIME TIME

MONEY DECIMAL(12,2),有2个小数位的定点值。

索引创建

MySQL

索引可以在表创建时用CREATE TABLE语句指定。

mSQL

在表被创建了以后,索引必须被创建,用单独的CREATE INDEX语句。

把一个唯一标识符插入到一张表中

MySQL 使用AUTO_INCREMENT作为列类型修饰符。见20.4.29 mysql_insert_id()。

mSQL

在一张表上创建一个SEQUENCE并且选择_seq列。

为行获得一个唯一标识符

MySQL 向表中增加一个PRIMARY KEY或UNIQUE键。

mSQL 使用_rowid列。注意_rowid可以将来改变,取决于很多因素。

得到列最后被修改的时间

MySQL 在表中增加一个TIMESTAMP列。如果你不给出列值或如果你给它一个NULL值,该列自动为INSERT或UPDATE语句设置为当前的日期和时间。

mSQL 使用_timestamp列。

NULL值的比较

MySQL MySQL遵从ANSI SQL且与NULL的比较总是NULL。

mSQL 在mSQL中,NULL = NULL是TRUE(真)。当从mSQL到MySQL移植老的代码时,你必须将=NULL改委IS NULL,并将NULL改为IS NOT NULL。

字符串的比较

MySQL

通常,字符串比较以大小写无关方式按当前字符集(缺省为ISO-8859-1 Latin1)决定的排序次序实施。如果你不喜欢这样,声明你的列有BINARY属性,它使得比较根据用在MySQL服务器主机上的ASCII顺序进行。

mSQL

所有的字符串比较以大小写敏感的方式以ASCII顺序排序来进行。

大小写不敏感的搜索

MySQL

LIKE是一个大小写不敏感或大小写敏感的运算符,这取决于涉及的列。如果LIKE参数不以一个通配符字符开始,如有可能,MySQL则使用索引。

mSQL

使用CLIKE。

尾部空格的处理

MySQL

剥去CHAR和VARCHAR列尾部的空格。如果不希望这种行为,使用一个TEXT行列。

mSQL

保留尾部的空格。

WHERE子句

MySQL

MySQL正确地优先化任何东西(AND在OR前计算)。要想在MySQL里得到mSQL的行为,使用括号(如下所示)。

mSQL

从左到右计算任何东西。这意味着超过3个参数的一些逻辑运算不能以任何方式表示,它也意味着当你升级到MySQL时,你必须改变一些查询。你通过增加括号很容易做到这点。假定你有下列mSQL查询:

mysql>SELECT * FROM table WHERE a=1 AND b=2 OR a=3 AND b=4;

为了使MySQL像mSQL那样计算它,你必须增加括号:

mysql>SELECT * FROM table WHERE (a=1 AND (b=2 OR (a=3 AND (b=4))));

存取控制

MySQL

有表来存储对每个用户、主机和数据库的授权(许可)选项。见6.6 权限系统如何工作。

mSQL

有一个文件“mSQL.acl”,在哪里你能为用户授权读/写权限。

怎样对比MySQL与PostgreSQL

PostgreSQL有一些更高级的功能如定义用户类型、触发器、规则和一些事务支持。然而,PostgreSQL 缺乏很多来自 ANSI SQL和ODBC的很多标准类型和函数。对于一个完整的限制列表及其支持或不支持哪一个类型和函数,见crash-me网页。

通常,PostgreSQL是比MySQL慢很多。见10.8 使用你自己的基准。这大部分是由于他们的事务系统。如果你确实需要事务或PostgreSQL提供的丰富的类型体系并且你能承受速度的损失,你应该看看 PostgreSQL。

Java数据库连接(JDBC)由一组用 Java 编程语言编写的类和接口组成。JDBC 为工具/数据库开发人员提供了一个标准的 API,使他们能够用纯Java API 来编写数据库应用程序。然而各个开发商的接口并不完全相同,所以开发环境的变化会带来一定的配置变化。本文主要集合了不同数据库的连接方式。

一、连接各种数据库方式速查表

下面罗列了各种数据库使用JDBC连接的方式,可以作为一个手册使用。

1、Oracle8/8i/9i数据库(thin模式)

Class.forName(“oracle.jdbc.driver.OracleDriver”).newInstance();

String url=“jdbc:oracle:thin:@localhost:1521:orcl”; //orcl为数据库的SID

String user=“test”;

String password=“test”;

Connection conn= DriverManager.getConnection(url,user,password);

2、DB2数据库

Class.forName(“com.ibm.db2.jdbc.app.DB2Driver ”).newInstance();

String url=“jdbc:db2://localhost:5000/sample”; //sample为你的数据库名

String user=“admin”;

String password=“”;

Connection conn= DriverManager.getConnection(url,user,password);

3、Sql Server7.0/2000数据库

Class.forName(“com.microsoft.jdbc.sqlserver.SQLServerDriver”).newInstance();

String url=“jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=mydb”;

//mydb为数据库

String user=“sa”;

String password=“”;

Connection conn= DriverManager.getConnection(url,user,password);

4、Sybase数据库

Class.forName(“com.sybase.jdbc.SybDriver”).newInstance();

String url =“ jdbc:sybase:Tds:localhost:5007/myDB”;//myDB为你的数据库名

Properties sysProps = System.getProperties();

SysProps.put(“user”,“userid”);

SysProps.put(“password”,“user_password”);

Connection conn= DriverManager.getConnection(url, SysProps);

5、Informix数据库

Class.forName(“com.informix.jdbc.IfxDriver”).newInstance();

String url = “jdbc:informix-sqli://123.45.67.89:1533/myDB:INFORMIXSERVER=myserver;

user=testuser;password=testpassword”; //myDB为数据库名

Connection conn= DriverManager.getConnection(url);

6、MySQL数据库

Class.forName(“org.gjt.mm.mysql.Driver”).newInstance();

String url =“jdbc:mysql://localhost/myDB?user=soft&password=soft1234&useUnicode=true&characterEncoding=8859_1”

//myDB为数据库名

Connection conn= DriverManager.getConnection(url);

7、PostgreSQL数据库

Class.forName(“org.postgresql.Driver”).newInstance();

String url =“jdbc:postgresql://localhost/myDB” //myDB为数据库名

String user=“myuser”;

String password=“mypassword”;

Connection conn= DriverManager.getConnection(url,user,password);

8、access数据库直连用ODBC的

Class.forName(“sun.jdbc.odbc.JdbcOdbcDriver”) ;

String url=“jdbc:odbc:Driver={MicroSoft Access Driver (*.mdb)};DBQ=”+application.getRealPath(“/Data/ReportDemo.mdb”);

Connection conn = DriverManager.getConnection(url,“”,“”);

Statement stmtNew=conn.createStatement() ;

二、JDBC连接MySql方式

下面是使用JDBC连接MySql的一个小的教程

1、查找驱动程序

MySQL目前提供的java驱动程序为Connection/J,可以从MySQL 下载,并找到mysql-connector-java-3.0.15-ga-bin.jar文件,此驱动程序为纯java驱动程序,不需做其他配置。

2、动态指定classpath

如果需要执行时动态指定classpath,就在执行时采用-cp方式。否则将上面的.jar文件加入到classpath环境变量中。

3、加载驱动程序

try{

Class.forName(com.mysql.jdbc.Driver);

System.out.println(Success loading Mysql Driver!);

}catch(Exception e)

{

System.out.println(Error loading Mysql Driver!);

e.printStackTrace();

}

4、设置连接的url

jdbc:mysql://localhost/databasename[?pa=va][&pa=va]

三、以下列出了在使用JDBC来连接Oracle数据库时可以使用的一些技巧

1、在客户端软件开发中使用Thin驱动程序

在开发Java软件方面,Oracle的数据库提供了四种类型的驱动程序,二种用于应用软件、applets、servlets等客户端软件,另外二种用于数据库中的Java存储过程等服务器端软件。在客户机端软件的开发中,我们可以选择OCI驱动程序或Thin驱动程序。OCI驱动程序利用Java本地化接口(JNI),通过Oracle客户端软件与数据库进行通讯。Thin驱动程序是纯Java驱动程序,它直接与数据库进行通讯。为了获得最高的性能,Oracle建议在客户端软件的开发中使用OCI驱动程序,这似乎是正确的。但我建议使用Thin驱动程序,因为通过多次测试发现,在通常情况下,Thin驱动程序的性能都超过了OCI驱动程序。

2、关闭自动提交功能,提高系统性能

在第一次建立与数据库的连接时,在缺省情况下,连接是在自动提交模式下的。为了获得更好的性能,可以通过调用带布尔值false参数的Connection类的setAutoCommit()方法关闭自动提交功能,如下所示:

conn.setAutoCommit(false);

值得注意的是,一旦关闭了自动提交功能,我们就需要通过调用Connection类的commit()和rollback()方法来人工的方式对事务进行管理。

3、在动态SQL或有时间限制的命令中使用Statement对象

在执行SQL命令时,我们有二种选择:可以使用PreparedStatement对象,也可以使用Statement对象。无论多少次地使用同一个SQL命令,PreparedStatement都只对它解析和编译一次。当使用Statement对象时,每次执行一个SQL命令时,都会对它进行解析和编译。这可能会使你认为,使用PreparedStatement对象比使用Statement对象的速度更快。然而,我进行的测试表明,在客户端软件中,情况并非如此。因此,在有时间限制的SQL操作中,除非成批地处理SQL命令,我们应当考虑使用Statement对象。

此外,使用Statement对象也使得编写动态SQL命令更加简单,因为我们可以将字符串连接在一起,建立一个有效的SQL命令。因此,我认为,Statement对象可以使动态SQL命令的创建和执行变得更加简单。

4、利用helper函数对动态SQL命令进行格式化

在创建使用Statement对象执行的动态SQL命令时,我们需要处理一些格式化方面的问题。例如,如果我们想创建一个将名字O'Reilly插入表中的SQL命令,则必须使用二个相连的“''”号替换O'Reilly中的“'”号。完成这些工作的最好的方法是创建一个完成替换操作的helper方法,然后在连接字符串心服用公式表达一个SQL命令时,使用创建的helper方法。与此类似的是,我们可以让helper方法接受一个Date型的值,然后让它输出基于Oracle的to_date()函数的字符串表达式。

5、利用PreparedStatement对象提高数据库的总体效率

在使用PreparedStatement对象执行SQL命令时,命令被数据库进行解析和编译,然后被放到命令缓冲区。然后,每当执行同一个PreparedStatement对象时,它就会被再解析一次,但不会被再次编译。在缓冲区中可以发现预编译的命令,并且可以重新使用。在有大量用户的企业级应用软件中,经常会重复执行相同的SQL命令,使用PreparedStatement对象带来的编译次数的减少能够提高数据库的总体性能。如果不是在客户端创建、预备、执行PreparedStatement任务需要的时间长于Statement任务,我会建议在除动态SQL命令之外的所有情况下使用PreparedStatement对象。

6、在成批处理重复的插入或更新操作中使用PreparedStatement对象

如果成批地处理插入和更新操作,就能够显著地减少它们所需要的时间。Oracle提供的Statement和 CallableStatement并不真正地支持批处理,只有PreparedStatement对象才真正地支持批处理。我们可以使用addBatch()和executeBatch()方法选择标准的JDBC批处理,或者通过利用PreparedStatement对象的setExecuteBatch()方法和标准的executeUpdate()方法选择速度更快的Oracle专有的方法。要使用Oracle专有的批处理机制,可以以如下所示的方式调用setExecuteBatch():

PreparedStatement pstmt3D null;

try {

((OraclePreparedStatement)pstmt).setExecuteBatch(30);

...

pstmt.executeUpdate();

}

调用setExecuteBatch()时指定的值是一个上限,当达到该值时,就会自动地引发SQL命令执行,标准的executeUpdate()方法就会被作为批处理送到数据库中。我们可以通过调用PreparedStatement类的sendBatch()方法随时传输批处理任务。

7、使用Oracle locator方法插入、更新大对象(LOB)

Oracle的PreparedStatement类不完全支持BLOB和CLOB等大对象的处理,尤其是Thin驱动程序不支持利用PreparedStatement对象的setObject()和setBinaryStream()方法设置BLOB的值,也不支持利用setCharacterStream()方法设置CLOB的值。只有locator本身中的方法才能够从数据库中获取LOB类型的值。可以使用PreparedStatement对象插入或更新LOB,但需要使用locator才能获取LOB的值。由于存在这二个问题,因此,我建议使用locator的方法来插入、更新或获取LOB的值。

8、使用SQL92语法调用存储过程

在调用存储过程时,我们可以使用SQL92或Oracle PL/SQL,由于使用Oracle PL/SQL并没有什么实际的好处,而且会给以后维护你的应用程序的开发人员带来麻烦,因此,我建议在调用存储过程时使用SQL92。

9、使用Object SQL将对象模式转移到数据库中

既然可以将Oracle的数据库作为一种面向对象的数据库来使用,就可以考虑将应用程序中的面向对象模式转到数据库中。目前的方法是创建Java bean作为伪装的数据库对象,将它们的属性映射到关系表中,然后在这些bean中添加方法。尽管这样作在Java中没有什么问题,但由于操作都是在数据库之外进行的,因此其他访问数据库的应用软件无法利用对象模式。如果利用Oracle的面向对象的技术,可以通过创建一个新的数据库对象类型在数据库中模仿其数据和操作,然后使用JPublisher等工具生成自己的Java bean类。如果使用这种方式,不但Java应用程序可以使用应用软件的对象模式,其他需要共享你的应用中的数据和操作的应用软件也可以使用应用软件中的对象模式。

10、利用SQL完成数据库内的操作

我要向大家介绍的最重要的经验是充分利用SQL的面向集合的方法来解决数据库处理需求,而不是使用Java等过程化的编程语言。

如果编程人员要在一个表中查找许多行,结果中的每个行都会查找其他表中的数据,最后,编程人员创建了独立的UPDATE命令来成批地更新第一个表中的数据。与此类似的任务可以通过在set子句中使用多列子查询而在一个UPDATE命令中完成。当能够在单一的SQL命令中完成任务,何必要让数据在网上流来流去的?我建议用户认真学习如何最大限度地发挥SQL的功能。

篇10:Perl连接Oracle数据库

上次讲了在linux下安装Oracle,安装完之后可以用netac来配置远程数据库的本地命名,

要在perl下面连接oracle数据库,首先必须安装DBI和DBD for Oracle。

下面是一段perl程序

#!/usr/bin/perl

use DBI;

$dbname=“oralce”;

$user=“user”;

$passwd=“password”;

$dbh=“”;

$dbh = DBI->connect(“dbi:Oracle:$dbname”,$user,$passwd) or die “can't connect to

database ”. DBI-errstr;

//连接数据库

$sth=$dbh->prepare(“select * from tDevice”);

$sth->execute;

//执行sql语句

while (@recs=$sth->fetchrow_array) {

print $recs[0].“:”.$recs[1].“:”.$recs[2].“n”;

//读取记录数据

}

$dbh->disconnect;

//断开连接

国际贸易与数据库营销

flash课件下载

flash教学设计

Flash教学反思

flash教学课件

flash是什么意思中文翻译

数据库原理与应用教学设计

数据库设计文档范文

数据库参考文献格式

基于优先连接的复杂网络建模与仿真

flash与数据库的连接(共10篇)

欢迎下载DOC格式的flash与数据库的连接,但愿能给您带来参考作用!
推荐度: 推荐 推荐 推荐 推荐 推荐
点击下载文档 文档为doc格式
点击下载本文文档