《JAVA从入门到??》JDBC

什么是JDBC?

JDBC是Java DataBase Connectivity的缩写,它是Java程序访问数据库的标准接口。

使用Java程序访问数据库时,Java代码并不是直接通过TCP连接去访问数据库,而是通过JDBC接口来访问,而JDBC接口则通过JDBC驱动来实现真正对数据库的访问。

例如,我们在Java代码中如果要访问MySQL,那么必须编写代码操作JDBC接口。注意到JDBC接口是Java标准库自带的,所以可以直接编译。而具体的JDBC驱动是由数据库厂商提供的,例如,MySQL的JDBC驱动由Oracle提供。因此,访问某个具体的数据库,我们只需要引入该厂商提供的JDBC驱动,就可以通过JDBC接口来访问,这样保证了Java程序编写的是一套数据库访问代码,却可以访问各种不同的数据库,因为他们都提供了标准的JDBC驱动:
在这里插入图片描述

从代码来看,Java标准库自带的JDBC接口其实就是定义了一组接口,而某个具体的JDBC驱动其实就是实现了这些接口的类:
在这里插入图片描述

实际上,一个MySQL的JDBC的驱动就是一个jar包,它本身也是纯Java编写的。我们自己编写的代码只需要引用Java标准库提供的java.sql包下面的相关接口,由此再间接地通过MySQL驱动的jar包通过网络访问MySQL服务器,所有复杂的网络通讯都被封装到JDBC驱动中,因此,Java程序本身只需要引入一个MySQL驱动的jar包就可以正常访问MySQL服务器:
在这里插入图片描述

小结
使用JDBC的好处是:

各数据库厂商使用相同的接口,Java代码不需要针对不同数据库分别开发;

Java程序编译期仅依赖java.sql包,不依赖具体数据库的jar包;

可随时替换底层数据库,访问数据库的Java代码基本不变。

代码演示

将驱动和连接相关代码进行封装

package com.keith.sql;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

public class ConnectionUtils {
	private static final String URL = "jdbc:mysql://localhost:3306/gxa?useSSL=false&characterEncoding=utf8";
	private static final String USER= "root";
	private static final String PASSWORD = "123456";
	
	static Connection conn = null;
	static{
		try {
			Class.forName("com.mysql.jdbc.Driver");
		} catch (ClassNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		System.out.println("---连接成功---");
	}
	
	public static Connection getConnection() throws SQLException{
		conn = DriverManager.getConnection(URL, USER, PASSWORD);
		return conn;
	}
	
	public static void closeConn(){
		try {
			if (conn != null) {
				conn.close();
			}
		} catch (SQLException e) {		
			e.printStackTrace();
		}
	}
	
	
}

将ExecuteUpdate和ExecuteQuery封装
使用PreparedStatement可以完全避免SQL注入的问题,因为PreparedStatement始终使用?作为占位符,并且把数据连同SQL本身传给数据库,这样可以保证每次传给数据库的SQL语句是相同的,只是占位符的数据不同,还能高效利用数据库本身对查询的缓存。

package com.keith.sql;

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


public class DBUtils {
	 private static ResultSet rs = null;
	 private static Connection conn =null;
 	private static PreparedStatement ps = null;
 	
 	
        public static int myExecuteUpdate(String sql){
        	Connection conn =null;
        	PreparedStatement ps = null;
        	try{
        		 conn = ConnectionUtils.getConnection();
            	 ps = conn.prepareStatement(sql);
            	
            	int result = ps.executeUpdate();
            	
            	return result;
        	}catch(Exception e){
        		e.printStackTrace();
        	}finally {
        		try {
    				if(conn != null){
    					conn.close();
    				}
    				if(ps != null){
    					ps.close();
    				}
    				} catch (SQLException e) {			
    				e.printStackTrace();
    			}
			}
        	  return -1;
        }
        
     public static ResultSet myExecuteQuery(String sql,Object[] params){
    
     	try{
     		 conn = ConnectionUtils.getConnection();
     		ps = conn.prepareStatement(sql);
     		if (params.length > 0) {
				for(int i = 0; i<params.length; i++){
					ps.setObject(i+1,params[i]);
				}
			}
         	 rs = ps.executeQuery();      	
         	return rs;
     	}catch(Exception e){
     		e.printStackTrace();
     	}
  	 return null;
     }
        
     public static void closeQuery(){
        	try {
 				if(conn != null){
 					conn.close();
 				}
 				if(ps != null){
 					ps.close();
 				}
 				
 				if(rs != null){
 					ps.close();
 				}
 				} catch (SQLException e) {			
 				e.printStackTrace();
 			}
        }
        
        
}

进行查询操作

获取到JDBC连接后,下一步我们就可以查询数据库了。查询数据库分以下几步:

第一步,通过Connection提供的createStatement()方法创建一个Statement对象,用于执行一个查询;

第二步,执行Statement对象提供的executeQuery(“SELECT * FROM students”)并传入SQL语句,执行查询并获得返回的结果集,使用ResultSet来引用这个结果集;

第三步,反复调用ResultSet的next()方法并读取每一行结果。

package com.keith.sql;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Scanner;

public class DemoSelect {

	public static void main(String[] args) throws SQLException {
         Scanner sc = new Scanner(System.in);
         System.out.print("输入雇员编号:");
         String empno = sc.nextLine();
         System.out.print("输入雇员名称:");
         String ename = sc.nextLine();

		String sql = "select * from emp where empno = ? and ename = ?";
		Object[] params = {empno,ename};
		ResultSet rs = DBUtils.myExecuteQuery(sql,params);
		if(rs.next()){
			System.out.println("==雇员信息属实==");
		}else{
			System.out.println("==无此雇员信息==");
		}
		
		sc.close();
				DBUtils.closeQuery();
	}

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值