JDBC

一、认识

JDBC(Java DataBase Connectivity)是Java和数据库之间的一个桥梁,是一个规范而不是一个实现,能够执行SQL语句。它由一组用Java语言编写的类和接口组成。简单说:JDBC是以统一方式访问数据库的API.

二、JDBC提供

     1.独立于平台的数据库访问

     2.位置透明

     3.对专有数据库的问题是透明

三、JDBC和JDBC Drivers

     1.JDBC Drivers是实现数据库操作的类

     Drivers分成两类:

       (1)2-层-客户直接和数据库会话

        (2)3层-客户与代表数据库的中间件(WebLogicServer)会话

四、使用JDBC直接访问数据库

通过初始化驱动类com.mysql.jdbc.Driver,该类就在 mysql-connector-java-5.0.8-bin.jar中。

源码示例:

     
public static Connection getConnection(){
		Connection conn = null;
		 try {
			 	//加载JDBC驱动类com.mysql.jdbc.Driver
	            Class.forName("com.mysql.jdbc.Driver");
	            conn = DriverManager.getConnection("jdbc:mysql://192.168.22.1:3306/exam?characterEncoding=UTF-8","root", "admin");
	            //该类就在 mysql-connector-java-5.0.8-bin.jar中,如果忘记了第一个步骤的导包,就会抛出ClassNotFoundException
	        } catch (ClassNotFoundException e) { 				
	            e.printStackTrace();
	        }catch (SQLException e) {							
	            e.printStackTrace();
	        }
		 return conn;
	}

五、使用多层(Type3)Drivers

   要使用多层体系结构,必须至少配置一个连接池(connection Pool)和一个数据源(DataSource)

 连接池的功能:

 1.消除频繁建立连接所需的负载

2.是用于管理数据库连接的管理对象

3.提供可共享,安全的连接

六、创建和配置数据源DataSources

1.从JDBC Services中选Data Sources

2.配置新的数据源

3.指定文件

4.绑定JND数据源中的名字

5.连接池关联数据源DataSource

 

七、注意

在JDBC编码的过程中我们创建了Connection、ResultSet等资源,这些资源在使用完毕之后是一定要进行关闭的。关闭的过程中遵循从里到外的原则。因为在增删改查的操作中都要用到这样的关闭操作,为了使代码简单,增加其复用性,这里我将这些关闭的操作写成一个方法和建立连接的方法一起放到一份工具类中。

/**
     * 封装三个关闭方法
     * @param pstmt
     */
    public static void close(PreparedStatement pstmt){
        if(pstmt != null){                        //避免出现空指针异常
            try{
                pstmt.close();
            }catch(SQLException e){
                e.printStackTrace();
            }
            
        }
    }
    
    public static void close(Connection conn){
        if(conn != null){
            try {
                conn.close();
            } catch (SQLException e) {
                // TODO: handle exception
                e.printStackTrace();
            }
        }
    }
    
    public static void close(ResultSet rs){
        if (rs != null) {
            try {
                rs.close();
            } catch (SQLException e) {
                // TODO: handle exception
                e.printStackTrace();
            }
        }
    }

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值