最全JDBC超详细入门教程,kafka面试题1001kafka面试题

一线互联网大厂Java核心面试题库

image

正逢面试跳槽季,给大家整理了大厂问到的一些面试真题,由于文章长度限制,只给大家展示了部分题目,更多Java基础、异常、集合、并发编程、JVM、Spring全家桶、MyBatis、Redis、数据库、中间件MQ、Dubbo、Linux、Tomcat、ZooKeeper、Netty等等已整理上传,感兴趣的朋友可以看看支持一波!

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

  1. 释放资源

  2. 注意:后期都会使用PreparedStatement来完成增删改查的所有操作

  3. 可以防止SQL注入

  4. 效率更高

抽取JDBC工具类 : JDBCUtils


  • 目的:简化书写

  • 分析:

  1. 注册驱动也抽取

  2. 抽取一个方法获取连接对象

  • 需求:不想传递参数(麻烦),还得保证工具类的通用性。

  • 解决:配置文件

jdbc.properties

url=

user=

password=

  1. 抽取一个方法释放资源
  • 代码实现:

public class JDBCUtils {

private static String url;

private static String user;

private static String password;

private static String driver;

/**

  • 文件的读取,只需要读取一次即可拿到这些值。使用静态代码块

*/

static{

//读取资源文件,获取值。

try {

//1. 创建Properties集合类。

Properties pro = new Properties();

//获取src路径下的文件的方式—>ClassLoader 类加载器

ClassLoader classLoader = JDBCUtils.class.getClassLoader();

URL res = classLoader.getResource(“jdbc.properties”);

String path = res.getPath();

System.out.println(path);///D:/IdeaProjects/itcast/out/production/day04_jdbc/jdbc.properties

//2. 加载文件

// pro.load(new FileReader(“D:\IdeaProjects\itcast\day04_jdbc\src\jdbc.properties”));

pro.load(new FileReader(path));

//3. 获取数据,赋值

url = pro.getProperty(“url”);

user = pro.getProperty(“user”);

password = pro.getProperty(“password”);

driver = pro.getProperty(“driver”);

//4. 注册驱动

Class.forName(driver);

} catch (IOException e) {

e.printStackTrace();

} catch (ClassNotFoundException e) {

e.printStackTrace();

}

}

/**

  • 获取连接

  • @return 连接对象

*/

public static Connection getConnection() throws SQLException {

return DriverManager.getConnection(url, user, password);

}

/**

  • 释放资源

  • @param stmt

  • @param conn

*/

public static void close(Statement stmt,Connection conn){

if( stmt != null){

try {

stmt.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

if( conn != null){

try {

conn.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

}

/**

  • 释放资源

  • @param stmt

  • @param conn

*/

public static void close(ResultSet rs,Statement stmt, Connection conn){

if( rs != null){

try {

rs.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

if( stmt != null){

try {

stmt.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

if( conn != null){

try {

conn.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

}

}

  • 练习:

  • 需求:

  1. 通过键盘录入用户名和密码

  2. 判断用户是否登录成功

  • select * from user where username = “” and password = “”;

  • 如果这个sql有查询结果,则成功,反之,则失败

  • 步骤:

  1. 创建数据库表 user

CREATE TABLE USER(

id INT PRIMARY KEY AUTO_INCREMENT,

username VARCHAR(32),

PASSWORD VARCHAR(32)

);

INSERT INTO USER VALUES(NULL,‘zhangsan’,‘123’);

INSERT INTO USER VALUES(NULL,‘lisi’,‘234’);

  1. 代码实现:

public class JDBCDemo9 {

public static void main(String[] args) {

//1.键盘录入,接受用户名和密码

Scanner sc = new Scanner(System.in);

System.out.println(“请输入用户名:”);

String username = sc.nextLine();

System.out.println(“请输入密码:”);

String password = sc.nextLine();

//2.调用方法

boolean flag = new JDBCDemo9().login(username, password);

//3.判断结果,输出不同语句

if(flag){

//登录成功

System.out.println(“登录成功!”);

}else{

System.out.println(“用户名或密码错误!”);

}​

}​

/**

  • 登录方法

*/

public boolean login(String username ,String password){

if(username == null || password == null){

return false;

}

//连接数据库判断是否登录成功

Connection conn = null;

Statement stmt = null;

ResultSet rs = null;

//1.获取连接

try {

conn = JDBCUtils.getConnection();

//2.定义sql

String sql = “select * from user where username = '”+username+“’ and password = '”+password+"’ ";

//3.获取执行sql的对象

stmt = conn.createStatement();

//4.执行查询

rs = stmt.executeQuery(sql);

//5.判断

/* if(rs.next()){//如果有下一行,则返回true

return true;

}else{

return false;

}*/

return rs.next();//如果有下一行,则返回true

} catch (SQLException e) {

e.printStackTrace();

}finally {

JDBCUtils.close(rs,stmt,conn);

}

return false;

}

}

JDBC控制事务:


  1. 事务:一个包含多个步骤的业务操作。如果这个业务操作被事务管理,则这多个步骤要么同时成功,要么同时失败。

  2. 操作:

  3. 开启事务

  4. 提交事务

  5. 回滚事务

  6. 使用Connection对象来管理事务

  • 开启事务:setAutoCommit(boolean autoCommit) :调用该方法设置参数为false,即开启事务

  • 在执行sql之前开启事务

  • 提交事务:commit()

  • 当所有sql都执行完提交事务

  • 回滚事务:rollback()

  • 在catch中回滚事务

  1. 代码:

public class JDBCDemo10 {

public static void main(String[] args) {

Connection conn = null;

PreparedStatement pstmt1 = null;

PreparedStatement pstmt2 = null;

try {

//1.获取连接

conn = JDBCUtils.getConnection();

//开启事务

conn.setAutoCommit(false);

//2.定义sql

//2.1 张三 - 500

String sql1 = “update account set balance = balance - ? where id = ?”;

//2.2 李四 + 500

String sql2 = “update account set balance = balance + ? where id = ?”;

//3.获取执行sql对象

pstmt1 = conn.prepareStatement(sql1);

pstmt2 = conn.prepareStatement(sql2);

//4. 设置参数

pstmt1.setDouble(1,500);

pstmt1.setInt(2,1);

pstmt2.setDouble(1,500);

pstmt2.setInt(2,2);

//5.执行sql

pstmt1.executeUpdate();

// 手动制造异常

int i = 3/0;

pstmt2.executeUpdate();

//提交事务

conn.commit();

} catch (Exception e) {

//事务回滚

try {

if(conn != null) {

conn.rollback();

}

} catch (SQLException e1) {

e1.printStackTrace();

}

e.printStackTrace();

}finally {

JDBCUtils.close(pstmt1,conn);

JDBCUtils.close(pstmt2,null);

}

}

}

笔者福利

以下是小编自己针对马上即将到来的金九银十准备的一套“面试宝典”,不管是技术还是HR的问题都有针对性的回答。

有了这个,面试踩雷?不存在的!

回馈粉丝,诚意满满!!!




本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

mt1,conn);

JDBCUtils.close(pstmt2,null);

}

}

}

笔者福利

以下是小编自己针对马上即将到来的金九银十准备的一套“面试宝典”,不管是技术还是HR的问题都有针对性的回答。

有了这个,面试踩雷?不存在的!

回馈粉丝,诚意满满!!!

[外链图片转存中…(img-z1x7yLcU-1715574347501)]
[外链图片转存中…(img-OSJGyCWg-1715574347502)]
[外链图片转存中…(img-2APihyKZ-1715574347503)]
[外链图片转存中…(img-vRHpExAb-1715574347503)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

  • 12
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
面试官问到大数据Kafka面试,可能会涉及以下几个方面的内容: 1. Kafka的基本概念和特点: - Kafka是一个分布式流处理平台,用于高吞吐量的实时数据传输。 - Kafka采用发布-订阅模式,消息以topic为单位进行发布和订阅。 - Kafka具有高可靠性、可扩展性和持久性等特点。 2. Kafka的架构和组件: - Kafka集群由多个broker组成,每个broker负责存储和处理消息。 - 每个topic可以分为多个分区,每个分区可以在不同的broker上进行复制。 - 生产者将消息发布到指定的topic,消费者从指定的topic订阅消息。 3. Kafka的消息传输和存储: - Kafka使用消息日志的方式存储消息,每个分区都有一个对应的日志文件。 - 生产者将消息追加到分区的日志文件末尾,消费者按照偏移量顺序读取消息。 - Kafka支持消息的持久化存储,并且可以根据配置进行数据的保留和清理。 4. Kafka的高可用和容机制: - Kafka通过副本机制实现高可用性,每个分区可以有多个副本。 - 副本之间通过ISR(In-Sync Replicas)机制保持同步,确保数据的一致性。 - 当某个broker宕机时,Kafka会自动将其上的分区副本迁移到其他可用的broker上。 5. Kafka的性能调优和监控: - 可以通过调整Kafka的参数来提高性能,如调整分区数、批量发送消息等。 - 监控Kafka集群的健康状态,包括吞吐量、延迟、存储空间等指标。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值