java练气期(1)----java高级(JDBC)

1.什么是JDBC?

JDBC: Java Database Connectivity  为多种关系型数据库提供统一访问。即通过Java代码访问和操作数据库

JDBC连接数据库的步骤

//JDBC的工具类代码,为持久层服务
package com.lkw.util;

import java.sql.*;




public class DBHelper {
    /**
	 * <pre>
	 * JDBC驱动程序,默认为MySQL
	 * MySQL: <b>com.mysql.jdbc.Driver</b>
	 * MSSQLServer: <b>com.microsoft.sqlserver.jdbc.SQLServerDriver</b>
	 * </pre>
	 */
    private static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";

    /**
	 * <pre>
	 * JDBC数据库URL,默认为MySQL
	 * MySQL:<b>jdbc:mysql://localhost:3306/数据库名</b>
	 * MSSQLServer:<b>jdbc:sqlserver://localhost:1433;DatabaseName=数据库名</b>
	 * </pre>
	 */
    private static final String JDBC_URL = "jdbc:mysql://localhost:3306/exam";

   /**
	 * JDBC登录数据库服务器用户名和密码
	 */
    private static final String JDBC_USER = "root";
    private static final String JDBC_PASSWORD = "root";

    private static DBHelper db = null;
    private  static Connection conn = null;
    private  static PreparedStatement st = null;

   static {
       try {
           //加载驱动程序
           Class.forName(JDBC_DRIVER);
       } catch (ClassNotFoundException e) {
           e.printStackTrace();
       }


   }
   private  DBHelper() throws SQLException {
        //获取数据库连接
       conn = DriverManager.getConnection(JDBC_URL, JDBC_USER, JDBC_PASSWORD);
   }

    //获取DBHelper对象
   public static  DBHelper getInstance() throws SQLException {
        if(db == null || conn.isClosed()) {
            db = new DBHelper();
        }
        return db;
   }

//查询
   public ResultSet executeQuery(String sql, Object...args) throws SQLException {
        st  = conn.prepareStatement(sql);//预处理
        if(args != null && args.length > 0) {
            for(int i = 0; i < args.length; ++i)
            {
                st.setObject(i + 1, args[i]);
            }
        }
        return st.executeQuery();
   }
//增删改
   public int executeUpdate(String sql, Object...args) throws SQLException {
       st = conn.prepareStatement(sql);
       if(args != null && args.length > 0) {
          for(int i = 0; i < args.length; ++i) {
              st.setObject(i + 1, args[i]);
          }
       }

       return st.executeUpdate();
   }

   /*关闭对象*/
    public static void close() {
        if(st != null ) {
            try {
                st.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }finally {
                if(conn != null){
                    try {
                        conn.close();
                    } catch (SQLException e) {
                        e.printStackTrace();
                    }finally{
                        st = null;
                        conn = null;
                        db = null;
                    }
                }
            }
        }

    }


}

2. 简述JDBC的Resulset,与Connection类

ResultSet是结果集,用来存放执行sql后返回的执行结果,对应于数据库中的数据表

Connrction:与数据库连接的对象

 

3.JDBC中,PreparedStatement相较于Statement有什么优点?

1)PreparedStatement可以使用预编译的sql,而Statment只能使用静态的sql

2)PreparedStatement可以使用sql缓存区,效率比Statment高

3)PreparedStatement可以有效防止sql注入,而Statment不能防止sql注入。

4.JDBC中如何进行事务处理?

一个事务是由一条或多条对数据库操作的SQL语句所组成的一个不可分割的工作单元,只有当事务中的所有操作都正常执行了,整个事务才会被提交给数据库。在JDBC中,一般是通过commit()方法或rollback()方法来结束事务的操作。其中commit()方法表示完成对事务的提交,rollback()方法表示完成事务回滚,多用于在处理事务的过程中出现了异常的情况,这两种方法都位于java.sql.Connection类中。一般而言,事务默认操作是自动提交,即操作成功后,系统将自动调用commit()方法,否则将调用rollback()方法。

当然,在JDBC中,也可以通过调用setAutoCommit(false)方法来禁止自动提交,然后就可以把多个数据库操作的表达式作为一个事务,在操作完成后调用commit()方法实现整体提交,如果其中一个表达式操作失败,就会抛出异常而不会调用commit()方法。在这种情况下,就可以在异常捕获的代码块中调用rollback()进行事务回滚。通过此种方法可以保持对数据库的多次操作后,数据仍然保持一致性。

JDBC事务处理的方法

try{
     con.setAutoCommit(false);//开启事务
     ......
     con.commit();//try的最后提交事务      
} catch() {
    con.rollback();//回滚事务
}

 

 

 5.在进行数据库编程时,连接池有什么作用?

实际开发中“获得连接”或“释放资源”是非常消耗系统资源的两个过程,为了解决此类性能问题,通常情况我们采用连接池技术,来共享连接Connection。

用池来管理Connection,这样可以重复使用Connection。有了池,所以我们就不用自己来创建Connection,而是通过池来获取Connection对象。当使用完Connection后,调用Connection的close()方法也不会真的关闭Connection,而是把Connection“归还”给池。池就可以再利用这个Connection对象了。

 

常见的连接池有C3P0、DBCP。

C3P0开源免费的连接池!目前使用它的开源项目有:Spring、Hibernate等。使用第三方工具需要导入jar包,c3p0使用时还需要添加配置文件c3p0-config.xml。

DBCP也是一个开源的连接池,是Apache Common成员之一,在企业开发中也比较常见,tomcat内置的连接池。

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值