MySQL第六章、JDBC编程

目录

一、数据库编程的必备条件

二、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,可以为多种关系数据库提供统一访问。

MySQL第六章、JDBC编程_第1张图片 


三、JDBC工作原理

JDBC 为多种关系数据库提供了统一访问方式,作为特定厂商数据库访问API的一种高级抽象,它主要包含一些通用的接口类。

MySQL第六章、JDBC编程_第2张图片

 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();
    }
}

MySQL第六章、JDBC编程_第3张图片

MySQL第六章、JDBC编程_第4张图片

 

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();
    }
}

MySQL第六章、JDBC编程_第5张图片

MySQL第六章、JDBC编程_第6张图片

MySQL第六章、JDBC编程_第7张图片

你可能感兴趣的:(MySQL数据库,mysql,数据库,JDBC,java,开发语言)