0
点赞
收藏
分享

微信扫一扫

MySQL最后一讲:JDBC 编程 - java - 细节狂魔

盖码范 2022-03-21 阅读 90
java后端

文章目录

JDBC编程是什么?

在这里插入图片描述


怎么写一个JDBC的代码?

1、使用idea创建项目 - 学Java的,可以不看。


引入依赖


写代码


准备工作


JDBC 编程 的 基本流程


1、创建 DataSource 对象,这个对象描述了数据库服务器在哪


第一个括号:setURL()

在这里插入图片描述


2、setUser()

在这里插入图片描述


3、setPassword()

在这里插入图片描述


2、让代码和数据库服务器建立连接


3、进行操作数据库:以插入数据为例


4、执行SQL


5、此时 SQL 已经执行完毕,然后需要我们去释放资源


总程序 - 初始版本 - insert 插入操作

import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;

import javax.sql.DataSource; // JDBC 所在的包,用于提供 JDBC 的 类和方法。
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;

public class TestJDBC {
    public static void main(String[] args) throws SQLException {
        // 1、创建好数据源
        // DataSource 就是 JDBC 当中一个重要的 “类”(实际上它是接口)
        DataSource dataSource = new MysqlDataSource();
        // 设置数据库所在的地址
        ((MysqlDataSource)dataSource).setURL("jdbc:mysql://127.0.0.1:3306/java?characterEncoding=utf8&useSSL=false");
        // 设置 登录数据库的用户名
        ((MysqlDataSource)dataSource).setUser("root");
        //  设置登录数据库的密码
        ((MysqlDataSource)dataSource).setPassword("123456");


        //2、让代码与数据库服务器建立连接
        Connection connection = dataSource.getConnection();

        //进行操作数据库:以插入数据为例
        //关键所在就是构造一个 SQL 语句。
        String sql = "insert into student values(1,'张三')";
        //但是呢,光有一个String类型的SQL还不行。需要把这个String 包装成一个“语句对象”。
        PreparedStatement preparedStatement= connection.prepareStatement(sql);

        //4、执行SQL:真正访问数据库服务器,插入数据
        // SQL 里面的 insert、update、delete,都是是哦用 executeUpdate 方法
        // 【可以这么理解:这三操作其实都是在更新数据。而 executeUpdate 的中文意思就是执行更新】
        //  select 很特殊,使用的是 executeQuery 方法。
        // 【而 select 不涉及数据更新操作,它只是查询数据的内容。executeQuery的中文意思就是 执行询问/执行查询】
        int ret = preparedStatement.executeUpdate();
        //  preparedStatement.executeUpdate() 就是拿着我们构造好的 语句对象去进行相应的操作。
        // 并且它会返回一个整数,意思就是 这个操作 影响到了几行
        System.out.println(ret);

        //5、此时 SQL 已经执行完毕,然后需要我们去释放资源
        preparedStatement.close();
        connection.close();
    }
}

效果图

在这里插入图片描述


进阶

构造SQL语句的优化

在这里插入图片描述


优化后的总程序 - insert 插入操作

在这里插入图片描述


效果图

在这里插入图片描述


小拓展:获取连接失败的原因


delete 删除操作

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 TestJDBCDelete {
    public static void main(String[] args) throws SQLException {
        Scanner sc = new Scanner(System.in);
        DataSource dataSource = new MysqlDataSource();
        ((MysqlDataSource)dataSource).setURL("jdbc:mysql://127.0.0.1:3306/java?characterEncoding=utf8&useSSL=false");
        ((MysqlDataSource)dataSource).setUser("root");
        ((MysqlDataSource)dataSource).setPassword("123456");

        Connection connection = dataSource.getConnection();
        System.out.println("请输入要删除信息人的ID:");
        int id = sc.nextInt();

        String sql = "delete from student where id = ?";
        PreparedStatement preparedStatement = connection.prepareStatement(sql);

        preparedStatement.setInt(1,id);

        int ret = preparedStatement.executeUpdate();
        System.out.println(ret);

        preparedStatement.close();
        connection.close();
        sc.close();
    }
}

在这里插入图片描述


update 更新操作

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 TestJDBCUpdate {
    public static void main(String[] args) throws SQLException {
        Scanner sc = new Scanner(System.in);
        DataSource dataSource = new MysqlDataSource();
        ((MysqlDataSource)dataSource).setURL("jdbc:mysql://127.0.0.1:3306/java?characterEncoding=utf8&useSSL=false");
        ((MysqlDataSource)dataSource).setUser("root");
        ((MysqlDataSource)dataSource).setPassword("123456");
        Connection connection = dataSource.getConnection();
        System.out.println("请输入修改信息人的ID:");
        int id = sc.nextInt();
        System.out.println("请输入修改姓名:");
        String name = sc.next();
        String sql = "update student set name = ? where id = ?";
        PreparedStatement preparedStatement = connection.prepareStatement(sql);
        preparedStatement.setString(1,name);
        preparedStatement.setInt(2,id);
        System.out.println("preparedStatement:"+preparedStatement);
        int ret = preparedStatement.executeUpdate();
        System.out.println(ret);

        preparedStatement.close();
        connection.close();
        sc.close();
    }
}

在这里插入图片描述


优化后的总程序 - select 查询操作


查询程序
import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;

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

public class TestJDBCSelect {
    public static void main(String[] args) throws SQLException {
        //1、创建数据源
        DataSource dataSource = new MysqlDataSource();
        ((MysqlDataSource)dataSource).setURL("jdbc:mysql://127.0.0.1:3306/java?characterEncoding=utf8&useSSL=false");
        ((MysqlDataSource)dataSource).setUser("root");
        ((MysqlDataSource)dataSource).setPassword("123456");

        // 2、建立连接
        Connection connection = dataSource.getConnection();

        //3、构建SQL语句
        String sql = "select * from student";

        //4、将字符串风格的SQL语句包装秤 “语句对象"
        PreparedStatement preparedStatement= connection.prepareStatement(sql);

        //5、执行SQL语句,与之不同的是 select 的执行方法是 executeQuery()
        //查询操作我们都知道它返回是一个临时表。
        // 所以用来接收的变量类型 不能是 常见的数据类型了。
        ResultSet resultSet = preparedStatement.executeQuery();
        //executeQuery 的返回值类型根据  点击进入原码就可以知道为 ResultSet 类型。
        // 获取数据的思路:先获取到每一行,再获取到这一行中的若干列

        // 通过next 方法,来获取到一行记录,同时把光标往后移动一行。
        // 如果遍历到表的结束为止,此处的 next 直接返回 false.
        // 循环条件为假,终止循环。
        // 下面是 student 表 全列查询的结果
//              +------+--------+
//              | id   | name   |
//              +------+--------+
//              |    2 | 王五   |
//              |    6 | 赵六   |
//              +------+--------+
        while(resultSet.next()){
            int id = resultSet.getInt("id");
            String name = resultSet.getString("name");
            System.out.println("id = " + id + ", name = " + name);
        }
        preparedStatement.close();
        connection.close();
    }
}

拓展: 基于反射来描述数据库服务器的位置

// 加载JDBC驱动程序:反射,这样调用初始化com.mysql.jdbc.Driver类,即将该类加载到JVM方法区,并执行该类的静态方法块、静态属性。
Class.forName("com.mysql.jdbc.Driver");
// 创建数据库连接
Connection connection =DriverManager.getConnection("jdbc:mysql://localhost:3306/test?
user=root&password=root&useUnicode=true&characterEncoding=UTF-8");
举报

相关推荐

0 条评论