本代码实现连接 本机数据库的方法。

操作步骤:

1、进入控制面板,打开“管理工具→数据源(ODBC)”,弹出“ODBC数据源管理器”,在“用户DSN”选项卡中,单击选中名称为“Visio Database Sample”,驱动程序为“Microsoft Access Driver(*.mdb,*.accdb)”的选项(注意:*.mdb 是ACCESS 2003的数据库扩展名,*.accdb是access 2007及以上的扩展名,如果看不到该选项,请确认已经安装access软件),然后单击 “添加”按钮,弹出“创建新数据源”对话框,选择“Microsoft Access Driver(*.mdb,*.accdb)”(对access 2003 和 access2007均适用),单击“完成”按钮,弹出 "ODBC Microsoft Access 安装" 对话框,在 数据源名 中输入 你的access 数据库名称,比如 “book”,然后单击 “选择”按钮,在弹出的 对话框中找到 你电脑上的数据库文件(如我的 “book”数据库文件),最后单击确定按钮,返回相应的对话框,然后选择 “确定” “完成”,最后回到 “ODBC数据源管理器”可以看到 用户数据源中出现了“book”数据源,

2、连接数据库的关键语句:

加载驱动程序:
String sDriver="sun.jdbc.odbc.JdbcOdbcDriver";
Class.forName(sDriver);

连接数据库:
Connection dbCon=null;
String sCon="jdbc:odbc:book"; //book 就是数据库名称
dbCon=DriverManager.getConnection(sCon);

执行数据库操作:
Statement stmt=stmt=dbCon.createStatement();
String sSQL="SELECT * "+" FROM bookindex";
ResultSet rs=stmt.executeQuery(sSQL);
while(rs.next()){
 int num;
 System.out.print(rs.getString("BookID")+"  ");  //输出对应字段的值
 System.out.print(rs.getString("BookTitle")+"  ");
 System.out.print(rs.getString("BookAuthor"));
 System.out.println("  " +rs.getFloat("BookPrice"));
}

关闭数据库连接
stmt.close();
dbCon.close();

实例代码如下(有 book数据库,表bookindex,字段有 :BookID、BookTitle、BookAuthor、BookPrice)

  1. <SPAN style="FONT-SIZE: 18px">import java.sql.*;
  2. public class DBconnTest {
  3. public static void main(String args[]) {
  4. //步骤1:加载驱动程序
  5. String sDriver="sun.jdbc.odbc.JdbcOdbcDriver";
  6. try{
  7. Class.forName(sDriver);
  8. }
  9. catch(Exception e){
  10. System.out.println("无法加载驱动程序");
  11. return;
  12. }
  13. System.out.println("步骤1:加载驱动程序——成功!");
  14. Connection dbCon=null;
  15. Statement stmt=null;
  16. String sCon="jdbc:odbc:book";
  17. try{
  18. dbCon=DriverManager.getConnection(sCon);
  19. if(dbCon!=null){
  20. System.out.println("步骤2:连接数据库——成功!");
  21. }
  22. //步骤3:建立JDBC的Statement对象
  23. stmt=dbCon.createStatement();
  24. if(stmt!=null){
  25. System.out.println("步骤3:建立JDBC的Statement对象——成功!");
  26. }
  27. }
  28. catch(SQLException e){
  29. System.out.println("连接错误:"+sCon);
  30. System.out.println(e.getMessage());
  31. if(dbCon!=null){
  32. try{
  33. dbCon.close();
  34. }
  35. catch(SQLException e2){}
  36. }
  37. return;
  38. }
  39. try{//执行数据库查询,返回结果
  40. String sSQL="SELECT * "+" FROM bookindex";
  41. ResultSet rs=stmt.executeQuery(sSQL);
  42. while(rs.next()){
  43. System.out.print(rs.getString("BookID")+"  ");
  44. System.out.print(rs.getString("BookTitle")+"  ");
  45. System.out.print(rs.getString("BookAuthor"));
  46. System.out.println("  " +rs.getFloat("BookPrice"));
  47. }
  48. }
  49. catch(SQLException e){
  50. System.out.println(e.getMessage());
  51. }
  52. finally{
  53. try{
  54. //关闭步骤3所开启的statement对象
  55. stmt.close();
  56. System.out.println("关闭statement对象");
  57. }
  58. catch(SQLException e){}
  59. try{
  60. //关闭数据库连接
  61. dbCon.close();
  62. System.out.println("关闭数据库连接对象");
  63. }
  64. catch(SQLException e){}
  65. }
  66. }
  67. }
  68. </SPAN>
import java.sql.*;
public class DBconnTest {
public static void main(String args[]) {
//步骤1:加载驱动程序
String sDriver="sun.jdbc.odbc.JdbcOdbcDriver";
try{
Class.forName(sDriver);
}
catch(Exception e){
System.out.println("无法加载驱动程序");
return;
}
System.out.println("步骤1:加载驱动程序——成功!");
Connection dbCon=null;
Statement stmt=null;
String sCon="jdbc:odbc:book";
try{
dbCon=DriverManager.getConnection(sCon);
if(dbCon!=null){
System.out.println("步骤2:连接数据库——成功!");
}
//步骤3:建立JDBC的Statement对象
stmt=dbCon.createStatement();
if(stmt!=null){
System.out.println("步骤3:建立JDBC的Statement对象——成功!");
}
}
catch(SQLException e){
System.out.println("连接错误:"+sCon);
System.out.println(e.getMessage());
if(dbCon!=null){
try{
dbCon.close();
}
catch(SQLException e2){}
}
return;
}
try{//执行数据库查询,返回结果
String sSQL="SELECT * "+" FROM bookindex";
ResultSet rs=stmt.executeQuery(sSQL);
while(rs.next()){
System.out.print(rs.getString("BookID")+" ");
System.out.print(rs.getString("BookTitle")+" ");
System.out.print(rs.getString("BookAuthor"));
System.out.println(" " +rs.getFloat("BookPrice"));
}
}
catch(SQLException e){
System.out.println(e.getMessage());
}
   finally{
    try{
     //关闭步骤3所开启的statement对象
     stmt.close();
     System.out.println("关闭statement对象");
    }
    catch(SQLException e){}
    try{
     //关闭数据库连接
     dbCon.close();
     System.out.println("关闭数据库连接对象");
    }
    catch(SQLException e){}
   }
  }
}

上面的方法问题:只对本机有效,换个电脑就找不到数据源了,需要重新配置 access数据源

在连接数据库时,可以直接指定数据库 的路径,最好将数据库和源文件放到一个目录里,这样就不用再配置数据源了。方法如下:

将指定数据源语句代码更改为如下:

原先代码:

String sCon="jdbc:odbc:book";

更改后代码:(注意,这里将数据库与程序源文件放到同一目录下,如果用 eclipse 则是放到 项目文件夹中,与.classpath 同级。

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

也可以在eclipse 中建立个文件夹 比如 DB 文件夹,则语句还要加上目录如下:

String sCon = "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ=DB/book.mdb";

实例如下:

  1. <SPAN style="FONT-SIZE: 18px">import java.sql.*;
  2. public class DBconnTest {
  3. public static void main(String args[]) {
  4. //步骤1:加载驱动程序
  5. String sDriver="sun.jdbc.odbc.JdbcOdbcDriver";
  6. try{
  7. Class.forName(sDriver);
  8. }
  9. catch(Exception e){
  10. System.out.println("无法加载驱动程序");
  11. return;
  12. }
  13. System.out.println("步骤1:加载驱动程序——成功!");
  14. Connection dbCon=null;
  15. Statement stmt=null;
  16. String sCon = "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ=book.mdb";
  17. try{
  18. dbCon=DriverManager.getConnection(sCon);
  19. if(dbCon!=null){
  20. System.out.println("步骤2:连接数据库——成功!");
  21. }
  22. //步骤3:建立JDBC的Statement对象
  23. stmt=dbCon.createStatement();
  24. if(stmt!=null){
  25. System.out.println("步骤3:建立JDBC的Statement对象——成功!");
  26. }
  27. }
  28. catch(SQLException e){
  29. System.out.println("连接错误:"+sCon);
  30. System.out.println(e.getMessage());
  31. if(dbCon!=null){
  32. try{
  33. dbCon.close();
  34. }
  35. catch(SQLException e2){}
  36. }
  37. return;
  38. }
  39. try{//执行数据库查询,返回结果
  40. String sSQL="SELECT * "+" FROM bookindex";
  41. ResultSet rs=stmt.executeQuery(sSQL);
  42. while(rs.next()){
  43. System.out.print(rs.getString("BookID")+"  ");
  44. System.out.print(rs.getString("BookTitle")+"  ");
  45. System.out.print(rs.getString("BookAuthor"));
  46. System.out.println("  " +rs.getFloat("BookPrice"));
  47. }
  48. }
  49. catch(SQLException e){
  50. System.out.println(e.getMessage());
  51. }
  52. finally{
  53. try{
  54. //关闭步骤3所开启的statement对象
  55. stmt.close();
  56. System.out.println("关闭statement对象");
  57. }
  58. catch(SQLException e){}
  59. try{
  60. //关闭步骤3所开启的statement对象
  61. dbCon.close();
  62. System.out.println("关闭数据库连接对象");
  63. }
  64. catch(SQLException e){}
  65. }
  66. }
  67. }
  68. </SPAN>

转载 JAVA SE 连接ACCESS的更多相关文章

  1. java远程连接access数据库

    本文转载自http://www.voidcn.com/article/p-tlrtkqlp-k.html 1  rmijdbc远程连接access数据库 正常情况下,常用的数据库sql server, ...

  2. java项目连接access数据库

    1.导入Access_JDBC30.jar到项目中 jar包百度云链接:https://pan.baidu.com/s/10HFM3HomMArvfHjklA_1MA 密码:0qxp 项目名称-> ...

  3. Java连接Access数据库的那些坑

    Java 使用 JDBC 连接Access数据库 需要掌握的技能 1.Java SE基本技术 2.懂点JDBC技术 能够学到如何使用Java正确的连接JDBC 环境 window8.1 64位 jdk ...

  4. java连接access数据库

    完整代码: package odbcj; import java.sql.Connection; import java.sql.DriverManager; import java.sql.Prep ...

  5. java连接Access数据库的两种方法

    where ziduan  in(select  ziduan from  table) 嵌套 ResultSet rs = pst.executeQuery();List list = new Ar ...

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

    本文是对前几天的"JDBC连接Access数据库的几种方式"这篇的升级.因为在做一些小项目的时候遇到的问题,因此才决定写这篇博客的.昨天已经将博客公布了.可是后来经过一些验证有点问 ...

  7. MySQL java连接被拒绝:java.sql.SQLException: Access denied for user 'root'@'****' (using password: YES)

    //系统运行出现错误:java.sql.SQLException: Access denied for user 'root'@'***.**.**.**' (using password: YES) ...

  8. Java 连接Access

    Java 连接Access 第一次使用连接Access数据库, 记录一下遇到的坑 Access驱动下载地址 http://pan.baidu.com/s/1o8ltTfc 不使用WINDOW的建立数据 ...

  9. Eclipse使用jdbc连接MySql数据库报:java.sql.SQLException: Access denied for user 'root'@'localhost' (using password: YES)

    在使用eclipse连接mysql数据库时报异常: java.sql.SQLException: Access denied for user 'root'@'localhost' (using pa ...

随机推荐

  1. ssl证书验证的问题

    对于https请求,是需要ssl证书验证的请求的,所以如果在请求时如果不带ssl证书,那么可以忽略证书的验证 有三种方法去实现: 1.Requests请求: 在文档中可以看到:http://docs. ...

  2. xpath教程一---简单的标签搜索

    工具 Python3版本 lxml库[优点是解析快] HTML代码块[从网络中获取或者自己杜撰一个] requests[推荐安装,从网页上获取网页代码练手,再好不过了] 讲解 网页代码都是成对的标签, ...

  3. 【Docker 命令】- rm命令

    docker rm :删除一个或多少容器 语法 docker rm [OPTIONS] CONTAINER [CONTAINER...] OPTIONS说明: -f :通过SIGKILL信号强制删除一 ...

  4. PHPCMS登录后不是进入会员中心而是转入登录前页最新代码

    phpcms比如会员在登录前是停留在下载页面的,但是下载页面是要求会员登录后才能下载,所以会员就有这个登陆过程,但是一般的会员系统是登录进会员中心的,就会有点体验不好  这里教大家修改下 能达到登录后 ...

  5. BZOJ 1806 矿工配餐(DP)

    很水的DP. 因为每一个餐车的加入只需要知道当前矿洞的前两个餐车种类就行了.而餐车一共就三种. 所以令dp[i][Sa][Sb]表示前i辆餐车送餐完毕后第一个矿洞的前两个餐车种类为Sa,第二个矿洞的前 ...

  6. 【题解】CF#855 G-Harry Vs Voldemort

    个人感觉挺有意思的,然而被颜神D无聊惹(- ̄▽ ̄)- 这题我们可以首先试图去统计以每一个点作为 w 点所能对答案造成的贡献是多少.不难发现,当且仅当 u 和 v 都在 w 所在边双的一侧的时候不能构成 ...

  7. 【题解】SHOI2014概率充电器

    首先发现答案就是每个节点有电的概率之和.有电的概率牵扯太广不好求,所以转化为求没有电的概率.这题最难的部分在于:一个节点如果有电,可以来自儿子,也可以来自父亲.我们考虑将这两个部分分离开来:建立状态 ...

  8. 【刷题】BZOJ 1717 [Usaco2006 Dec]Milk Patterns 产奶的模式

    Description 农夫John发现他的奶牛产奶的质量一直在变动.经过细致的调查,他发现:虽然他不能预见明天产奶的质量,但连续的若干天的质量有很多重叠.我们称之为一个"模式". ...

  9. 牛客网 Wannafly挑战赛27 蓝魔法师

    蓝魔法师 链接: https://www.nowcoder.com/acm/contest/215/C 来源:牛客网 题目描述 "你,你认错人了.我真的,真的不是食人魔."--蓝魔 ...

  10. HDU 5651 逆元

    xiaoxin juju needs help Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/ ...