MySQL最后一讲:JDBC 编程 - java - 细节狂魔,2024年最新如何优化sql语句面试题

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注Java)
img

正文

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

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

localhost 就是 127.0.0.1

首先我要声明一点:非常不推荐这样去写

1、因为 反射 属于编程中的“非常规手段”,反射如果在代码中使用的多了,是非常影响代码的可读性的。也不利于IDEA对代码进行解析校验。

2、这种写法相比于DataSource来说,DataSource 更好用。

因为DataSource内置了连接池,在频繁 创建/断开 链接的时候,这里的DataSource就要比 DriverManager的方式更加高效。

这是因为 DataSource 中涉及到一个关键字 “池”【连接池 - Connection pool】,学过JavaSE的朋友,是不是觉得很熟悉,跟我们在学String的时候, 接触的 字符串常量池 很像。其实两者含义完全相同。

池的作用:就是把你可能用到东西都装在一个“池子”里,你要用的时候,直接往“池”里拿。池里有,它就直接给你,而且相当于给你可一个克隆的备份(就是说给了你之后,池里面还有,你下回还可以接着用),没有就创建一个给你。

所以DataSource更加高效!!!!

最后

面试前一定少不了刷题,为了方便大家复习,我分享一波个人整理的面试大全宝典

  • Java核心知识整理

2020年五面蚂蚁、三面拼多多、字节跳动最终拿offer入职拼多多

Java核心知识

  • Spring全家桶(实战系列)

2020年五面蚂蚁、三面拼多多、字节跳动最终拿offer入职拼多多

  • 其他电子书资料

2020年五面蚂蚁、三面拼多多、字节跳动最终拿offer入职拼多多

Step3:刷题

既然是要面试,那么就少不了刷题,实际上春节回家后,哪儿也去不了,我自己是刷了不少面试题的,所以在面试过程中才能够做到心中有数,基本上会清楚面试过程中会问到哪些知识点,高频题又有哪些,所以刷题是面试前期准备过程中非常重要的一点。

以下是我私藏的面试题库:

2020年五面蚂蚁、三面拼多多、字节跳动最终拿offer入职拼多多

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

Java核心知识

  • Spring全家桶(实战系列)

[外链图片转存中…(img-uFgUnht2-1713641730111)]

  • 其他电子书资料

[外链图片转存中…(img-SSa3xKaM-1713641730112)]

Step3:刷题

既然是要面试,那么就少不了刷题,实际上春节回家后,哪儿也去不了,我自己是刷了不少面试题的,所以在面试过程中才能够做到心中有数,基本上会清楚面试过程中会问到哪些知识点,高频题又有哪些,所以刷题是面试前期准备过程中非常重要的一点。

以下是我私藏的面试题库:

[外链图片转存中…(img-I3MVjQR9-1713641730112)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-9fvyZh9h-1713641730113)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 26
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值