分享
 
 
 

使用JavaApplet访问数据库

王朝java/jsp·作者佚名  2008-05-19
窄屏简体版  字體: |||超大  

学习任何的程序语言,当然都得与数据库,Java刚刚诞生的时候,对数据库的支持并不是很好,经过这几年的发展,它对数据库的支持也已经完全达到了成熟的境地。由于这里主要是介绍Java Applet小程序, 因此,不可能用大的篇幅去给大家介绍数据库的知识了,怎么样去建立与设计数据库,还是请大家自己找点书看看吧!这儿,对不住了。

我们这儿以Microsoft Access数据库为例子来说明怎么实现一个数据库的打开与读取的知识。

第一步:

使用Microsoft Access创建一个数据库,也就是我的这个例子要用到的,内容就随便了。

第二步:也就是编程序了。

1)定义变量,变量的定义如下:

TextArea theVisits=new TextArea (6,80);

//显示数据库的内容

TextField theStatus=new TextField ("",80);

//显示打开数据库的信息。相当于程序的状态栏

Connection theConnection; //数据库的连接方法

Statement theStatement; //代表一个发送到数据库来执行的数据库命令

ResultSet theResult; //读取的数据结果,也就是数据库返回的结果

ResultSetMetaData theMetaData;

//包含了有关数据库命令执行后 返回结果的有用信息。

String theDataSource; //包含了被访问数据库或者数据源的名称,用URL形式表示 .

String theUser; //数据库的用户名

String thePassword; //数据库的密码

2)实现界面,可以用开始时给大家介绍的方法来实现,界面的实现相对来说,

比较的简单了,如下:

public void init()

{

add(theVisits);

add(theStatus);

theVisits.setEditable (false); //设置文本区域不可以被用户写入

theStatus.setEditable (false); //设置文本区域不可以被用户写入

openConnection(); //打开数据库的连接

execSqlCommand("select * from MyTable"); //从数据库中读取内容

closeConnection(); //关闭已经打开的数据库

}

3)打开某个数据库的连接

public void openConnection()

{

theDataSource="jdbc:odbc:MyAccess";

theUser="";

thePassword="";

try

{

Class.forName("Sun.jdbc.odbc.JdbcOdbcDriver");

theConnection=DriverManager.getConnection(theDataSource,theUser,thePassword);

theStatus.setText("Status:OK");

}

catch (Exception e)

{

handleException(e);

}

}

包含数据源名称的字符串格式为一个特殊的语句:

jdbc::

协议 名jdbc必须提供,子协议和子名称根据使用数据源类型而变化。

JDBC DriverManager使用子协议来选择书记源响应的驱动程序。子协议

的通常值为“odbc”和“oracle“,子名称包含了该驱动程序使用的附加

信息。通常情况,该子名称是某个网络名称,例如,用于其它Web服务:

jdba::///

驱动程序的说明应该指定子协议和子名称的正确形式。使用ODBC时,主机和端口信息没有必要提供,因为数据源总是配置在本地主机上。用于ODBC数据源的形式是

jdbc:odbc:

为了打开数据库连接,用户必须使用具体的驱动程序另外,驱动程序应该指 定如何这样做。如果正在使用JDBC-ODBC桥程序,那么可以通过使用名为Class类 的forName()方法来使用具体的JDBC-ODBC桥驱动程序。

class.forName("sun.jdbc.JdbcOdbcDriver");

然后,拥护可以告诉rManager打开数据源的连接,使用下列方法:

theConnection=DriverManager.getConnection(theDataSource,theUser,thePassword);

getConnection()方法返回一个Connection对象,用户应该保存这个对象, 因为它是访问数据源的方法。这里,该对象保存到名为theConnection的字段中。

如果在打开连接过程中出现错误,则SQLexception作废,通过在try-catch 块内打开连接的语句,拥护可以处理这种异常。通过使用后面要讲的handleException(), 在TextField内显示一个简短的相应信息。

4)执行SQL命令

public void execSQLCommand(String command)

{

try{

theStatement=theConnection.createStatement();

theResult=theStatement.executeQuery (command);

theMetaData=theResult.getMetaData ();

int columnCount=theMetaData.getColumnCount ();

theVisits.setText("");

while(theResult.next ())

{

for(int i =1;i

{

String colValue=theResult.getString(i);

if(colValue==null)colValue="";

theVisits.append (colValue+";");

}

theVisits.append ("\n");

}

}catch(Exception e)

{

handleException(e);

}

}

为了执行该命令,程序使用Connection对象的createStatement()方法创建 一个可以有查询的Statement。然后,它激活Statement对象的executiveQuery() 方法,用来传递包含SQL查询语句的字符串。从init()中传送过来的参数―― Slect * from MyTable是一个简单的数据库查询语言,如果你还不知道什么意思, 那么请你还是查看一本有关数据库的书吧,这些内容很多,不是我这儿一下子能说 清楚的了。它的意思简单的说,就是查找表――MyTable中的所有(*)信息。它会 返回数据库中的所有内容,并把它作为ResultSet访问的结果。接着该程序激活ResultSet 对象的getMetaData()方法。这时,返回一个ResultSetMetaData值,该值存储在 一个称为theMetaData的变量中。使用ResultSetMetaData对象,可以获得很多有用的 数据;这里该程序使用getColumnCount()方法获得结果表中列的数量。最后,该程序反 复使用该结果表,激活theResult的next()方法获得结果表中的每一条记录,只到该方法 使用完全部记录返回flase为止。

5)关闭数据库连接

public void closeConnection()

{

try{

theConnection.close ();

}

catch(Exception e)

{

handleException(e);

}

}

当用户访问完某个数据库时,应该关闭数据库连接,释放与连接有关的资源。用户创建 的任何打开的ResultSet或者Statement对象将 自动关闭。另外,在关闭连接时可能发 生一个SQLException,也放到后面处理。

6)处理异常和错误

public void handleException(Exception e)

{

theStatus.setText("Error:"+e.getMessage ());

e.printStackTrace ();

if(e instanceof SQLException)

{

while((e=((SQLException)e).getNextException ())!=null)

{

System.out.println(e);

}

}

}

handleException()方法用来处理以上的错误和异常。该方法设置状态TextField包含与 异常有关的错误消息,使用getMessage()方法获得该消息。它还可以在System.out打印 堆栈轨迹。

三 安装ODBC数据源

为了运行这个应用程序,用户必须 首先创建一个与MyTable数据库相对应的 ODBC数据源。 为了通过ODBC使用Access,用户必须安装Access Odbc驱动程序。如果用户没有安装该驱动 程序,那么还是先安装吧,什么,不会,不会也不行了,找一本书好好看看吧,这是肯定要 看的。我这儿简单的给你说一下吧:

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有