Java连接Access数据库执行增删改查操作

第一步,创建一个数据库,命名为MyAccessDB.mdb;

第二步,添加数据源。在“控制面板”中打开 “管理工具”找到ODBC数据源,双击打开。在用户DSN选项卡下选择MS Access Database,然后点击右侧“添加”按钮,选择Driver do Microsoft Access(*mdb),然后点击“完成”按钮。在弹出的安装对话框中,填写数据源名称“AccessData”,说明“数据源”,然后点击“选择”按钮,在弹出才对话框中,选择你所创建的数据库所在的目录,然后选中MyAccessDB.mdb,确定,确定,确定。

第三步,完成好以上工作好,就可以打开eclipse进行程序的编写了。现将代码拷贝如下:


(1)编写BaseDao.java

    package com.dao;  
      
    import java.sql.Connection;  
    import java.sql.DriverManager;  
    import java.sql.ResultSet;  
    import java.sql.SQLException;  
    import java.sql.Statement;  
      
    /** 
     * 联接数据源 
     * @author 刘仁奎 
     */  
    public class BaseDao {  
        Connection con = null;  
        Statement s = null;  
        ResultSet rs=null;  
          
        // 得到联接  
        public Connection getConnection(){  
            try {  
                // 加载JDBC-ODBC桥驱动程序  
                Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");  
                  
                // 方式一  通过驱动联接  
                con=DriverManager.getConnection("jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ=D:\\Technology\\Access2007\\MyAccessDB.mdb; pwd=liurenkui");  
                // 方式二 通过数据源与数据库建立连接  
                //con = DriverManager.getConnection("jdbc:odbc:AccessDatabase");  
            } catch (Exception e) {  
                e.printStackTrace();  
            }  
            return con;  
        }  
          
        /** 
         * 关闭数据源 
         */  
        public void CloseConnection(Connection con,ResultSet rs,Statement s){  
            try {  
                if (rs!=null) {  
                    rs.close();  
                }  
                if (s!=null) {  
                    s.close();  
                }  
                if (con!=null) {  
                    con.close();      
                }  
            } catch (SQLException e) {  
                e.printStackTrace();  
            }  
        }  
    }  

(2)编写测试类
    package com.test;  
      
    import java.sql.Connection;  
    import java.sql.ResultSet;  
    import java.sql.Statement;  
      
    import com.dao.BaseDao;  
      
    public class Test extends BaseDao{  
        Connection con = null;  
        Statement s = null;  
        ResultSet rs=null;  
        /** 
         * 执行查询 
         */  
        public void seach(){  
            try {  
                con=getConnection();  
                s = con.createStatement();// 创建SQL语句对象  
                rs=s.executeQuery("select * from employee");    // 查询员工信息  
                while (rs.next()) {  
                    System.out.println("编号:"+rs.getInt("ID")+",姓名:"+rs.getString("name")+",年龄:"+rs.getInt("age")+",入职日期:"+rs.getDate("entryDate"));  
                }  
                System.out.println("__________执行完毕___________ ");  
            } catch (Exception e) {  
                e.printStackTrace();  
            } finally {  
                CloseConnection(con, rs, s);  
            }  
        }  
          
        /** 
         * 执行增加 
         */  
        public void add(){  
            try {  
                int result=0;  
                con=getConnection();  
                s = con.createStatement();// 创建SQL语句对象  
                result=s.executeUpdate("insert into employee(id,name,age,entryDate) values('9','芳芳','19','2012-11-2')");  
                if (result>0) {  
                    System.out.println("插入成功");   
                }  
            } catch (Exception e) {  
                e.printStackTrace();  
            } finally {  
                CloseConnection(con, rs, s);  
            }  
            seach();  
        }  
          
        /** 
         * 执行修改 
         */  
        public void updata(){  
            try {  
                int result=0;  
                con=getConnection();  
                s = con.createStatement();// 创建SQL语句对象  
                result=s.executeUpdate("update employee set age=20 where id=6");  
                if (result>0) {  
                    System.out.println("更新成功");  
                }  
            } catch (Exception e) {  
                e.printStackTrace();  
            } finally {  
                CloseConnection(con, rs, s);  
            }  
            seach();  
        }  
          
        /** 
         * 执行删除 
         */  
        public void delete(){  
            try {  
                int result=0;  
                con=getConnection();  
                s = con.createStatement();// 创建SQL语句对象  
                result=s.executeUpdate("delete from employee where id=6");  
                if (result>0) {  
                    System.out.println("删除成功");  
                }  
            } catch (Exception e) {  
                e.printStackTrace();  
            } finally {  
                CloseConnection(con, rs, s);  
            }  
            seach();  
        }  
        public static void main(String[] args) {  
            Test t=new Test();  
            t.seach();  
    //      t.add();      
    //      t.updata();  
    //      t.delete();  
        }  
    }  


编程技巧