转载 JAVA SE 连接ACCESS
本代码实现连接 本机数据库的方法。
操作步骤:
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)
- <SPAN style="FONT-SIZE: 18px">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){}
- }
- }
- }
- </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";
实例如下:
- <SPAN style="FONT-SIZE: 18px">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:driver={Microsoft Access Driver (*.mdb)};DBQ=book.mdb";
- 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{
- //关闭步骤3所开启的statement对象
- dbCon.close();
- System.out.println("关闭数据库连接对象");
- }
- catch(SQLException e){}
- }
- }
- }
- </SPAN>
转载 JAVA SE 连接ACCESS的更多相关文章
- java远程连接access数据库
本文转载自http://www.voidcn.com/article/p-tlrtkqlp-k.html 1 rmijdbc远程连接access数据库 正常情况下,常用的数据库sql server, ...
- java项目连接access数据库
1.导入Access_JDBC30.jar到项目中 jar包百度云链接:https://pan.baidu.com/s/10HFM3HomMArvfHjklA_1MA 密码:0qxp 项目名称-> ...
- Java连接Access数据库的那些坑
Java 使用 JDBC 连接Access数据库 需要掌握的技能 1.Java SE基本技术 2.懂点JDBC技术 能够学到如何使用Java正确的连接JDBC 环境 window8.1 64位 jdk ...
- java连接access数据库
完整代码: package odbcj; import java.sql.Connection; import java.sql.DriverManager; import java.sql.Prep ...
- java连接Access数据库的两种方法
where ziduan in(select ziduan from table) 嵌套 ResultSet rs = pst.executeQuery();List list = new Ar ...
- Java Web项目中连接Access数据库的配置方法
本文是对前几天的"JDBC连接Access数据库的几种方式"这篇的升级.因为在做一些小项目的时候遇到的问题,因此才决定写这篇博客的.昨天已经将博客公布了.可是后来经过一些验证有点问 ...
- MySQL java连接被拒绝:java.sql.SQLException: Access denied for user 'root'@'****' (using password: YES)
//系统运行出现错误:java.sql.SQLException: Access denied for user 'root'@'***.**.**.**' (using password: YES) ...
- Java 连接Access
Java 连接Access 第一次使用连接Access数据库, 记录一下遇到的坑 Access驱动下载地址 http://pan.baidu.com/s/1o8ltTfc 不使用WINDOW的建立数据 ...
- 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 ...
随机推荐
- 3dContactPointAnnotationTool开发日志(十六)
调了一上午才发现是把下面这个函数: private float DivideTriangle(int []triangle,out int []outTriangle,List<Vector ...
- 分布式消息队列RocketMQ&Kafka -- 消息的“顺序消费”
在说到消息中间件的时候,我们通常都会谈到一个特性:消息的顺序消费问题.这个问题看起来很简单:Producer发送消息1, 2, 3... Consumer按1, 2, 3...顺序消费. 但实际情况却 ...
- css3 字体渐变
先看个效果 https://www.bienvillecapital.com/ 然后人家样式这样写的 font-family: Overpass,Helvetica,sans-serif; font- ...
- 【Python】爬虫与反爬虫大战
爬虫与发爬虫的厮杀,一方为了拿到数据,一方为了防止爬虫拿到数据,谁是最后的赢家? 重新理解爬虫中的一些概念 爬虫:自动获取网站数据的程序反爬虫:使用技术手段防止爬虫程序爬取数据误伤:反爬虫技术将普通用 ...
- Python Collections详解
Python Collections详解 collections模块在内置数据结构(list.tuple.dict.set)的基础上,提供了几个额外的数据结构:ChainMap.Counter.deq ...
- [洛谷P2742]【模板】二维凸包([USACO5.1]圈奶牛Fencing the Cows)
题目大意:求一个点集凸包边长 题解:求凸包,直接求 卡点:发现在较后面数位上有较小的误差,还以为是浮点数误差,最后发现是构造函数写成了$int$类型 C++ Code: #include <al ...
- [洛谷P5091]【模板】欧拉定理
题目大意:求$a^b\bmod m(a\leqslant10^9,m\leqslant10^6,b\leqslant10^{2\times10^7})$ 题解:扩展欧拉定理:$$a^b\equiv\b ...
- Codeforces Round #469 (Div. 2) E. Data Center Maintenance
tarjan 题意: 有n个数据维护中心,每个在h小时中需要1个小时维护,有m个雇主,他们的中心分别为c1,c2,要求这两个数据中心不能同时维护. 现在要挑出一个数据中心的子集,把他们的维护时间都推后 ...
- CF97B:Superset——题解
http://codeforces.com/problemset/problem/97/B 题目大意:给n个点,添加一些点,使得任意两个点: 1.在同一条线上 2.以它们为顶点构成的矩形上有其他点. ...
- [Leetcode] valid parentheses 有效括号对
Given a string containing just the characters'(',')','{','}','['and']', determine if the input strin ...