目录
一、数据库编程的必备条件
二、Java的数据库编程:JDBC
三、JDBC工作原理
四、JDBC使用
4.1JDBC开发案例
一、数据库编程的必备条件
- 编程语言,如Java,C、C++、Python等
- 数据库,如Oracle,MySQL,SQL Server等
- 数据库驱动包:不同的数据库,对应不同的编程语言提供了不同的数据库驱动包,如:MySQL提供了Java的驱动包mysql-connector-java,需要基于Java操作MySQL即需要该驱动包。同样的,要基于Java操作Oracle数据库则需要Oracle的数据库驱动包ojdbc。
二、Java的数据库编程:JDBC
JDBC,即Java Database Connectivity,java数据库连接。是一种用于执行SQL语句的Java API,它是Java中的数据库连接规范。这个API由java.sql.*,javax.sql.* 包中的一些类和接口组成,它为Java开发人员操作数据库提供了一个标准的API,可以为多种关系数据库提供统一访问。
三、JDBC工作原理
JDBC 为多种关系数据库提供了统一访问方式,作为特定厂商数据库访问API的一种高级抽象,它主要包含一些通用的接口类。
JDBC优势:
- Java语言访问数据库操作完全面向抽象接口编程
- 开发数据库应用不用限定在特定数据库厂商的API
- 程序的可移植性大大增强
四、JDBC使用
4.1JDBC开发案例
- 准备数据库驱动包,并添加到项目的依赖中:在项目中创建文件夹lib,并将依赖包mysql-connector-java-5.1.47.jar复制到lib中。再配置该jar包到本项目的依赖中:右键点击项目Open Module Settings,在Modules中,点击项目,配置Dependencies,点击+,JARS or Directories,将该lib文件夹配置进依赖中,表示该文件夹下的jar包都引入作为依赖。
- 建立数据库连接
import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;
import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.util.Scanner;
public class JDBCInsert {
public static void main(String[] args) throws SQLException {
//JDBC需要通过以下步骤完成开发
Scanner input=new Scanner(System.in);
//1.创建并初始化一个数据源
DataSource dataSource=new MysqlDataSource();
((MysqlDataSource)dataSource).setUrl("jdbc:mysql://127.0.0.1:3306/homework?characterEncoding=utf8&useSSL=false");
((MysqlDataSource)dataSource).setUser("root");
((MysqlDataSource)dataSource).setPassword("111111");
//2.和数据库服务器建立一个连接
Connection connection=dataSource.getConnection();
//3.构造SQL语句
System.out.println("请输入学生的姓名:");
String name=input.next();
System.out.println("请输入学生的编号:");
int id=input.nextInt();
String sql="insert into student values(?,?)";
PreparedStatement statement= connection.prepareStatement(sql);
statement.setInt(1,id);
statement.setString(2,name);
//4.执行SQL语句
int ret=statement.executeUpdate();
System.out.println("ret="+ret);
//5.释放必要的语句
statement.close();
connection.close();
}
}
import com.mysql.jdbc.Connection;
import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;
import javax.sql.DataSource;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
public class JDBCSelect {
public static void main(String[] args) throws SQLException {
//创建并初始化数据源
DataSource dataSourse=new MysqlDataSource();
((MysqlDataSource)dataSourse).setURL("jdbc:mysql://127.0.0.1:3306/homework?characterEncoding=utf8&useSSL=false");
((MysqlDataSource)dataSourse).setUser("root");
((MysqlDataSource)dataSourse).setPassword("111111");
//建立连接
Connection connection=dataSourse.getConnection()
//构造SQL语句
String sql="select * from student";
PreparedStatement statement= connection.prepareStatement(sql);
//执行SQL语句
ResultSet resultSet=statement.executeQuery();
//遍历结果集合
while(resultSet.next()){
//每次调用next,光标往下走一行
//通过getxxx获取当前行的数据
int id=resultSet.getInt("id");
String name=resultSet.getString("name");
System.out.println("id="+id+",name="+name);
}
//释放资源
resultSet.close();
statement.close();
connection.close();
}
}