当前位置:   article > 正文

java web access_Java Web项目中连接Access数据库的配置方法

java web如何配置access数据库有缓存吗

代码如下:

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

String url = "jdbc:odbc:JDBC-ODBC";

Connection con = DriverManager.getConnection(url);

以上的三行代码就是通过JDBC-ODBC连接Access数据库的关键代码。这种方式连接可以很方便的记忆连接的url代码,这是很有用的。后面的代码就是正常写了。

方式二:通过数据库所在的绝对路径方式连接

上面说过这里的几种方式都是基于JDBC-ODBC方式。所以加载驱动的Class.forName()中的参数都是“sun.jdbc.odbc.JdbcOdbcDriver”。对于这种方式我将student.mdb文件放在了e盘的根目录下,在使用的时候,直接写上该数据库的绝对路径就行了。获取连接的代码如下所示:

复制代码 代码如下:

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

String url = "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ="+"e://student.mdb ";

Connection con = DriverManager.getConnection(url);

对于这种方式不用配置数据源,虽然代码比较多,但是很好理解的。也是很常用的。

方式三:通过请求来获取数据库的绝对路径方式连接对于这种方式,我个人认为很适合在Java Web应用中使用,将做好的应用给别人,别人也可以使用。我将该数据库文件放在了Web应用的根路径下。那么动态的获取连接的代码如下所示:

复制代码 代码如下:

String path = application.getRealPath("/index.jsp");

path = path.substring(0,path.lastIndexOf("\\"))+"\\";

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

String url = "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ="+path+"student.mdb ";

Connection con = DriverManager.getConnection(url);

以上便是三种方式获取连接。接下来便是显示的代码了。代码如下所示:

复制代码 代码如下:

Access
学号姓名年龄地址语文数学英语

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

String url = "jdbc:odbc:JDBC-ODBC";

Connection con = DriverManager.getConnection(url);

Statement st = con.createStatement();

String sql = "select * from basic";

ResultSet rs = st.executeQuery(sql);

while(rs.next())

{

%>

}

rs.close();

st.close();

con.close();

%>

运行JSP结果如下所示:

371a2310bf18e214f204565ebe9b7da3.png

当将连接改为第二种方式的时候还是好使的,JSP代码如下所示:

运行JSP结果如下所示:

99c911e05e7c248180850b40610b2359.png

当将连接改为第三种方式的时候还是好使的,JSP代码如下所示:

运行JSP结果如下所示:

82cf99a30b65e6156805e6eee55e68b6.png

对于这种方式我的项目的目录结构如下所示:

4fb05aaeb7ec5216e3c2ee891ce7c4d0.png

第三种方式正是现在要用的方式,可以在Java类中,访问数据库了。

首先将mdb文件放入到WebRoot下面,当点击超链接的时候,将信息传给Servlet,在Servlet中写上如下的语句:

String path = request.getServletContext().getRealPath("/");

Dao dao = new Dao();

dao.init(path);

在dao的init()方法中初始化Connection连接:

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

String url = "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ="+path+"student.mdb ";

Connection con = DriverManager.getConnection(url);

这样在dao中就可以根据传过来的path找到数据库文件所在的路径了。并成功的连接到数据库了,实现了分层理念。

但是这样出现了一个问题,如果放在WebRoot下,别人知道数据库的位置,不就可以访问了吗?

为此我想了好久,既然是在Java类中访问数据库,那么能不能将mdb文件放在src下边呢,答案是可以的。这样在MyEclipse或Eclipse中,就将该文件复制到了Web项目的WEB-INF下的classes根路径下,不就能访问了,于是我的URL代码变成了这样:

String url = "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ=student.mdb ";

但是结果失败了,没有找到文件,但后来将该文件放到“项目”下,就好使了,但是这样一旦给别人,就又不行了,所以还得放到src下,只有这样才会放到WebRoot或WebContent下,才会放到classes下,才能被java类所访问,才能给别人项目就能运行。但是如何才能找到classes目录下的数据库文件呢。一直在找某个方法,直到找到了如下的方法:

方法一:Class类的getResource()方法或者是ClassLoader类的

bcc08c37fcfc6cc607beb9ee2909d51a.png

方法二:URL类的getPath()方法

2449c4334a2ffc8ed43fb230bde00813.png

通过Class类的getResource()方法查找当前类所在的目录,这里dao类在com.student.dao包下,那么该方法返回的就是该类的路径,如果参数是“/”的化,返回的就是classes的根目录,这样就可以得到classes下的数据库mdb文件的所在路径。再通过URL类的getPath()方法得到字符串类型的文件路径在服务器上的真实路径。

代码如下所示:

String path = this.getClass().getResource("/").getPath().replaceAll("%20"," ");//replaceAll方法是为了解决路径中含有空格字符的问题

path = path.substring(1,path.length());//对路径进行截取,获得的路径前边会多加一个杠Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");

String url = "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ="+path+"student.mdb";

con = DriverManager.getConnection(url);

将以上的代码封装DAO中,就可以访问到数据库了。就可以在Java Web项目中,使用Access数据库实现MVC设计模式,并添加DAO和VO了。对于使用Servlet API将mdb文件的路径传给dao是一种方式,使用dao封装Access也是一种方式,有时为了方便可以将mdb文件放到WebRoot下,通过JSP或者是Servlet将数据库文件的路径传给dao。我觉的Access数据库这一点比较好,可以将数据库和项目一起移动。通关这两种方式可以再任何的机器上运行。

目前,我所知道的就是这么做,我也认为这是比较好的作法。用Java语言连接数据库,将数据库文件放在和类路径相同的目录下是很好的作法。如果还有其他的办法,希望大家提出来。

本文是对前几天的“JDBC连接Access数据库的几种方式”这篇的升级。由于在做一些小项目的时候遇到的问题,因此才决定写这篇博客的。昨天已经将博客发布了,但是后来经过一些验证有点问题,所以今天改了一下重新的发布了

版权声明:本文为博主原创文章,未经博主允许不得转载。

Java Web项目中连接Access数据库的配置方法

标签:access   数据库

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:http://blog.csdn.net/xiaole0313/article/details/47609327

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/559227
推荐阅读
相关标签
  

闽ICP备14008679号