************连接方式(一)Access_JDBC30.jar,此包由于是免费的,所有限制连接单次不超过50*************************
 Connection conn = null;
 PreparedStatement stat = null;
 ResultSet rs=null;

//连接数据库(添加access数据库的驱动jar包:Access_JDBC30.jar)
public Connection openConn() {
  try {
   //这种方法连接access不需要access的驱动jar包Access_JDBC30.jar
   //String url = "JDBC:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ=D:/eclipse/project/jee/workspace/jubweb2/src/message.mdb";
   //Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
   
   //这种方法连接access需要access的驱动jar包Access_JDBC30.jar
   String url="jdbc:access:/D:/eclipse/project/jee/workspace/jubweb2/src/message.mdb";//不支持相对路径
   Class.forName("com.hxtt.sql.access.AccessDriver").newInstance();

Connection conn = DriverManager.getConnection(url);
   return conn;
  } catch (Exception e) {
   e.printStackTrace();
  }
  return null;
 }

//关闭数据库
 public void closeConn() {
  try {
   if (rs != null) {
    rs.close();
   }
   if (ps != null) {
    ps.close();
   }
   if (conn != null) {
    conn.close();
   }
  } catch (Exception e) {
   e.printStackTrace();
  }
 }

//添加
 public String addMessage(Yjfk yjfk) {
  conn =openConn();
  try {
   String sql = "insert into message values(?,?,?,?,?,?)";
   stat =openConn().prepareStatement(sql);
   stat.setString(1, UUID.randomUUID().toString());
   stat.setString(2, yjfk.getContent());
   stat.setString(3, yjfk.getCtype());
   stat.setString(4, yjfk.getName());
   stat.setString(5, yjfk.getEmail());
   stat.setString(6, yjfk.getPhone());
   stat.executeUpdate();
   return "success";
  } catch (Exception e) {
   e.printStackTrace();
  } finally {
   closeConn();
  }
  return "error";
 }
 
 //查询
 public List<Yjfk> qryMessage() throws SQLException{
  String sql = " select * from message ";
  stat = openConn().prepareStatement(sql);
  rs=stat.executeQuery();
  while (rs.next()) {
   System.out.println(rs.getString("content"));
   
  }
  closeConn();
  return null;
 }

************连接方式(二)JDBC-ODBC,jdk自带连接驱动,无需jar,但是需要配置本地电脑环境*************************

package com.qgc.tool;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

import org.apache.commons.dbcp.BasicDataSource;

/**
 * 使用abcp连接池
 * @author admin
 *所需JAR包:commons-pool-1.6.jar、commons-collections-3.2.1.jar、commons-dbcp-1.4.jar
 *
 */
public class Dbcp_Jdbc_odbc {
    private static final int INITIAL = 50;//初始化50个连接
    private static final int MAX_ACTIVE = 500;//最大值500个连接
    private static final int MAX_IDLE = 10;//最大空闲10
    private static final long MAX_WAIT = 2 * 1000;//超过500个访问,等待的时间
    private static final String DRIVER_NAME = "sun.jdbc.odbc.JdbcOdbcDriver";
    private static BasicDataSource bds;
    static{
        if(bds == null){
            bds = new BasicDataSource();
        }
        bds.setDriverClassName(DRIVER_NAME);
        bds.setInitialSize(INITIAL);
        bds.setMaxActive(MAX_ACTIVE);
        bds.setMaxIdle(MAX_IDLE);
        bds.setMaxWait(MAX_WAIT);
    }
    
    /**
     * 打开连接池
     * @param path 数据库的路径
     * @return
     * @throws SQLException
     */
    public static Connection getSqliteConnection(String path) throws SQLException{
        if(path==null){
            path="qqData";
        }
        /*qqData: 配置方式:控制面板->管理工具->ODBC->系统DSN->添加 Microsoft Access Driver(*.mdb)
        数据源名:sun (这个与你写的jdbc:odbc:sun对应)
        选择->你建的*.mdb的位置
        确定就可以用了
         */
        String url = "jdbc:odbc:"+path; //myDS 数据源名称;
        bds.setUrl(url);//数据库的路径
        return bds.getConnection();
    }

/**
     * 释放数据库连接
     *
     * @param rs
     * @param st
     * @param conn
     */
    public static void freeConnection(ResultSet rs, Statement st,
            Connection conn) {
        try {
            if (rs != null)
                rs.close();
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            try {
                if (st != null)
                    st.close();
            } catch (SQLException e) {
                e.printStackTrace();
            } finally {
                if (conn != null)
                    try {
                        conn.close();
                    } catch (SQLException e) {
                        e.printStackTrace();
                    }
            }
        }
    }
    
}

关于JDBC 连接Access 数据库的更多相关文章

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

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

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

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

  3. JDBC连接各种数据库的方法(经典)

    1)连接Oracle 8/8i/9i/10g/11g(thin模式) Class.forName("oracle.JDBC.driver.OracleDriver").newIns ...

  4. JSP连接access数据库

    一个用jsp连接Access数据库的代码. 要正确的使用这段代码,你需要首先在Access数据库里创建一username表,表里面创建两个字符型的字段,字段名分别为:uid,pwd,然后插入几条测试数 ...

  5. JDBC连接各种数据库的方法,连接MySql,Oracle数据库

    JDBC连接各种数据库的方法: JDBC编程步骤: 1.导入jar包 2.注册驱动 3.获取数据库连接对象 4.定义SQL语句 5.获得执行SQL语句对象statemnet 6.执行SQL语句 7.处 ...

  6. java远程连接access数据库

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

  7. 【.net 深呼吸】连接Access数据库应注意的几点

    本地数据库可以有Y种选择,比如Sqlite.SQL Server Express.SQL Local DB.SQL Server CE.Access等,本文老周选用比较著名的Access本地数据库,在 ...

  8. JDBC连接MySQL数据库代码模板

    下面这个例子是最简单的JDBC连接MySQL数据库的例子. 一般步骤: 1.注册驱动: 2.建立连接: 3.创建语句: 4.处理结果: 5.释放资源. 注意: 1.软件开发环境:MyEclipse 8 ...

  9. C#连接Access数据库(详解)

    做一个用VS2012的C#连接Access数据库的备忘, SQL数据库固然强大,有大微软的强力技术支持,LINQ的方便操作,但是如果写一个小程序对数据库方面没有什么大的要求的话,将来在数据库方面就可以 ...

随机推荐

  1. LeetCode Reverse Nodes in k-Group 每k个节点为一组,反置链表

    题意:给一个单链表,每k个节点就将这k个节点反置,若节点数不是k的倍数,则后面不够k个的这一小段链表不必反置. 思路:递归法.每次递归就将k个节点反置,将k个之后的链表头递归下去解决.利用原来的函数接 ...

  2. PHP基础 CGI,FastCGI,PHP-CGI与PHP-FPM

    CGI CGI全称是“公共网关接口”(Common Gateway Interface),HTTP服务器与你的或其它机器上的程序进行“交谈”的一种工具,其程序须运行在网络服务器上. CGI可以用任何一 ...

  3. Myeclipse 安装Aptana3.2 插件

    转自(http://www.cnblogs.com/yinger/archive/2011/08/29/2157193.html) 安装步骤: 1.下载aptana3.2 Eclipse Plugin ...

  4. 基于CentOS与VmwareStation10搭建Oracle11G RAC 64集群环境:4.安装Oracle RAC FAQ-4.5.安装Grid,创建ASM磁盘组空间不足

    因之前分区时,分区的Last cylinder的值选了“1”,导致创建磁盘组空间不足.解决办法是先删除分区,重新创建分区并删除ASM磁盘,然后重建ASM磁盘 1. 先删除分区,重新创建分区: 1)查询 ...

  5. windows 不能在本地计算机启动apache2 的解决方法(不是修改端口)

    使用命令行运行apache目录下的httpd程序,它会提示哪里出错了,修改即可 D:\Program Files (x86)\Apache2.\bin\httpd

  6. iostat的深入理解

    问题背景 iostat -xdm 1 通常用来查看机器磁盘IO的性能. 我们一般会有个经验值,比如,ioutil要小于80%, svctm要小于2ms. 前几天碰到一个奇怪的现象:有一台SSD机器,磁 ...

  7. JavaScript定时器与执行机制解析

    从JS执行机制说起 浏览器(或者说JS引擎)执行JS的机制是基于事件循环. 由于JS是单线程,所以同一时间只能执行一个任务,其他任务就得排队,后续任务必须等到前一个任务结束才能开始执行. 为了避免因为 ...

  8. check windows return character

    #ifndef _FILE_CHECK_H#define _FILE_CHECK_H#include <string.h>#include <vector> const int ...

  9. RandomAcessFile、MappedByteBuffer和缓冲读/写文件

    项目需要进行大文件的读写,调查测试的结果使我决定使用MappedByteBuffer及相关类进行文件的操作,效果不是一般的高. 网上参考资源很多,如下两篇非常不错: 1.花1K内存实现高效I/O的Ra ...

  10. Yii系列教程(四):使用Memcache保存会话

    1环境准备 安装Memcached服务端: yum -y installmemcached.x86_64 安装PHP-Memcache扩展: yum -y installphp-pecl-memcac ...