一.建立數據庫及ODBC數據源
1.建立jcc.mdb數據庫及user表
2.添加測試數據
3.配置ODBC數據源
二.在<%wwwroot%>/下,新建Access數據庫連接文件Select.jsp
Select.jsp源碼如下:
<%@page contentType="text/html;charset=gb2312"%>
<%@page import="java.sql.*"%>
<html>
<body>
<%
try{
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
}
catch(ClassNotFoundException e){
out.print(e);
}
try{
String url = "jdbc:odbc:jcc";
Connection conn = DriverManager.getConnection(url,"jcc","jsp.com.cn");
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("Select * FROM user");
out.println("User-list"+"<br>");
while(rs.next()){
out.print(rs.getString(1)+" ");
out.print(rs.getString(2)+"<br>");
}
rs.close();
stmt.close();
conn.close();
}
catch(Exception ex){
out.print(ex);
}
%>
</body>
</html>
四.運行http://localhost/Select.jsp,顯示結果如下:
User-list
1 Corebit
2 Ivan
則表示數據庫連接成功!恭喜!恭喜!
否則請檢查數據源相關設置,出錯可能性比較高!
附言:
常有人問起,如何在不做ODBC數據源的情況下讓JSP訪問Access數據庫,為解開這個迷團,特寫以下連接代碼,以供參考!其中,jcc.mdb與Select.jsp同位於<%wwwroot%>(根目錄)下。
改寫後的Select.jsp源碼如下:
<%@page contentType="text/html;charset=gb2312"%>
<%@page import="java.sql.*"%>
<html>
<body>
<%
try{
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
}
catch(ClassNotFoundException e){
out.print(e);
}
try{
String strDirPath=application.getRealPath(request.getRequestURI());
strDirPath=strDirPath.substring(0,strDirPath.lastIndexOf('\\'))+"\\";
String url = "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ="+strDirPath+"jcc.mdb";
Connection conn = DriverManager.getConnection(url);
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("Select * FROM user");
out.println("User-list"+"<br>");
while(rs.next()){
out.print(rs.getString(1)+" ");
out.print(rs.getString(2)+"<br>");
}
rs.close();
stmt.close();
conn.close();
}
catch(Exception ex){
out.print(ex);
}
%>
</body>
</html>
運行結果應該與使用ODBC時的運行結果相同!
*注:文件名Select.jsp區分大小寫!
希望本文能對你的JSP連接Access數據庫有所幫助!
==========================================
只能使用jdbc-odbc橋來連接
想要設置odbc數據源
然後連接
String dbdriver = "oracle.jdbc.driver.OracleDriver";
String dbname = "jdbc:oracle:thin:@192.168.0.101:1521:orcl";//根據你的情況修改
String user = "system";//用戶名
String password = "manager";//密碼
Connection conn = null;
Statement stmt = null;
ResultSet rs =null;
String sql="select * from 表名";//根據實際情況修改
try
{
Class.forName(dbdriver);
}
catch(java.lang.ClassNotFoundException e){
System.err.println("Class access_dbconnect not fount!"+e.getMessage());
}
conn=DriverManager.getConnection(dbname,user,password);
Statement stmt=conn.createStatement();
rs=stmt.executeQuery(sql);
=========================================
sDBDriver = "sun.jdbc.odbc.JdbcOdbcDriver";
sConnStr = "jdbc:odbc:odbc名稱";
conn = null;
rs = null;
try
{
Class.forName(sDBDriver);
}
conn = DriverManager.getConnection(sConnStr);
Statement statement = conn.createStatement();
rs = statement.executeQuery(s);
你在odbc數據源中建一個access連接,然後把上面的代碼中的odbc名稱改成你的odbc數據源連接名稱就可以了。