JDBC步骤及实现流程

JDBC步骤及实现流程

Java数据库连接,(Java Database Connectivity,简称JDBC)是Java语言中用来规范客户端程序如何来访问数据库的应用程序接口,提供了诸如查询和更新数据库中数据的方法。JDBC也是Sun Microsystems的商标。我们通常说的JDBC是面向关系型数据库的。

加载数据库驱动

在连接数据库之前,首先要加载想要连接的数据库的驱动加载到JVM,这通过java.lang.Class类的静态方法forName(String className)实现。

Class.forName("com.mysql.jdbc.Driver");

通过驱动管理类获取数据库连接

成功加载后,会将Driver类的实例注册到DriverManager类中,而DriverManager就是驱动管理类。

Connection connection =
DriverManager.getConnection("jdbc:mysql://localhost:3306/mybatis?
characterEncoding=utf-8", "root", "root");

定义SQL语句,并用?表示占位符

String sql = "select * from user where username = ?";

获取预处理对象statement

预处理(pre-treatment),是指在进行最后加工完善以前进行的准备过程,具体应用在不同的行业或领域,会有不同的解释。
预处理对象类即PrepareStatement

PreparedStatement preparedStatement = connection.prepareStatement(sql);

设置参数

设置参数,第一个参数为sql语句中参数的序号(从1开始),第二个参数为设置的参数值

preparedStatement.setString(1, "tom");

执行SQL

向数据库发出sql执行查询,查询出结果集

ResultSet resultSet = preparedStatement.executeQuery();

具体实现

遍历查询结果集并封装实体类

实体类User

public class User(){
     
	private int id;
	private String username;
	public void setId(int id){
     
		this.id = id;
	}	
	public int getId(){
     
		return id;
	}
	public void setUsername(String username){
     
		this.username = username;
	}
	public String getUsername(){
     
		return username;
	}
}

具体流程代码

如下:

public static void main(String[] args) {
     
	Connection connection = null;
	PreparedStatement preparedStatement = null;
	ResultSet resultSet = null;
	try {
     
		// 加载数据库驱动
		Class.forName("com.mysql.jdbc.Driver");
		// 通过驱动管理类获取数据库链接
		connection =
		DriverManager.getConnection("jdbc:mysql://localhost:3306/mybatis?
		characterEncoding=utf-8", "root", "root");
		// 定义sql语句?表示占位符
		String sql = "select * from user where username = ?";
		// 获取预处理statement
		preparedStatement = connection.prepareStatement(sql);
		// 设置参数,第一个参数为sql语句中参数的序号(从1开始),第二个参数为设置的参数值
		preparedStatement.setString(1, "tom");
		// 向数据库发出sql执行查询,查询出结果集
		resultSet = preparedStatement.executeQuery();
		// 遍历查询结果集
		while (resultSet.next()) {
     
			int id = resultSet.getInt("id");
			String username = resultSet.getString("username");
			// 封装User
			user.setId(id);
			user.setUsername(username);
			System.out.println(user);
		}
	} catch (Exception e) {
     
		e.printStackTrace();
	} finally {
     
		// 释放资源
		if (resultSet != null) {
     
			try {
     
				resultSet.close();
			} catch (SQLException e) {
     
				e.printStackTrace();
			}
		}
		if (preparedStatement != null) {
     
			try {
     
				preparedStatement.close();
			} catch (SQLException e) {
     
				e.printStackTrace();
			}
		}
		if (connection != null) {
     
			try {
     
				connection.close();
			} catch (SQLException e) {
     
				e.printStackTrace();
			}
		}
	}
}

你可能感兴趣的:(jdbc)