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

在这里插入图片描述


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

关键所在就是构造一个 SQL 语句。

知识铺垫:异常

在这里插入图片描述


4、执行SQL

真正访问数据库服务器,插入数据。

在这里插入图片描述


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

知识铺垫:资源释放。类似C语言中的动态开辟的空间需要通过free来释放空间

在这里插入图片描述

这是因为当创建好先关的链接之后,JVM 就会从系统这里申请到一些硬件资源。

这些资源,不用了就需要释放。

另外,释放资源是有先后顺序的。

需要先释放 preparedStatement,再去释放 connection。

(先创建的后释放,后创建的先释放)

举一个很形象的例子。

开冰箱拿东西。

先开冰箱门,再打开盒子。

拿完东西后,

先关上盒子,再关门。;

差不多就是意思。


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


写到这里,就已经写完一个基本的JDBC程序。

见到了一些新的概念(新的类)

DataSource/MysqlDataSource: 用来描述数据源,数据库的地址,端口,用户名、密码

Connection:表示数据库连接。

核心方法:getConnection

PreparedStatement:就通过这个对象来描述我们要执行的SQL语句。

核心方法:prepareStatement


SQL语句执行的核心方法

insert、delete、update :executeUpdate 方法

select:executeQuery




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 插入操作

在这里插入图片描述


效果图

在这里插入图片描述


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

1、数据库的地址不对

2、端口号不对

3、数据库名不对

4、用户名不对

5、密码不对

6、其他情况


delete 删除操作

由于非常简单,和上面 insert 操作几乎一毛一样。就是修改 构造的SQL语句就行了。

我就不讲太多,直接上程序。


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



### 最后如何让自己一步步成为技术专家


说句实话,如果一个打工人不想提升自己,那便没有工作的意义,毕竟大家也没有到养老的年龄。

当你的技术在一步步贴近阿里p7水平的时候,毫无疑问你的薪资肯定会涨,同时你能学到更多更深的技术,交结到更厉害的大牛。

**推荐一份Java架构之路必备的学习笔记,内容相当全面!!!**

![](https://img-blog.csdnimg.cn/img_convert/e509c0d2af5d605896c125bec37f6996.webp?x-oss-process=image/format,png)

成年人的世界没有容易二字,前段时间刷抖音看到一个程序员连着加班两星期到半夜2点的视频。在这个行业若想要拿高薪除了提高硬实力别无他法。

你知道吗?现在有的应届生实习薪资都已经赶超开发5年的程序员了,实习薪资26K,30K,你没有紧迫感吗?做了这么多年还不如一个应届生,真的非常尴尬!

进了这个行业就不要把没时间学习当借口,这个行业就是要不断学习,不然就只能被裁员。所以,抓紧时间投资自己,多学点技术,眼前困难,往后轻松!

**【关注】+【转发】+【点赞】支持我!创作不易!**

加入社区:https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0
prepareStatement(sql);



### 最后如何让自己一步步成为技术专家


说句实话,如果一个打工人不想提升自己,那便没有工作的意义,毕竟大家也没有到养老的年龄。

当你的技术在一步步贴近阿里p7水平的时候,毫无疑问你的薪资肯定会涨,同时你能学到更多更深的技术,交结到更厉害的大牛。

**推荐一份Java架构之路必备的学习笔记,内容相当全面!!!**

[外链图片转存中...(img-PwV01ZD9-1725701875358)]

成年人的世界没有容易二字,前段时间刷抖音看到一个程序员连着加班两星期到半夜2点的视频。在这个行业若想要拿高薪除了提高硬实力别无他法。

你知道吗?现在有的应届生实习薪资都已经赶超开发5年的程序员了,实习薪资26K,30K,你没有紧迫感吗?做了这么多年还不如一个应届生,真的非常尴尬!

进了这个行业就不要把没时间学习当借口,这个行业就是要不断学习,不然就只能被裁员。所以,抓紧时间投资自己,多学点技术,眼前困难,往后轻松!

**【关注】+【转发】+【点赞】支持我!创作不易!**

加入社区:https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值