JDBC知识点总结

1.什么是JDBC?

JDBC: Java Database Connectivity
 java数据库连接,即使用java代码发送sql语句的技术,为多种关系型数据库提供统一访问。

 

2.简述JDBC连接数据库的步骤。

加载驱动  创建连接  执行sql并返回执行结果  处理结果   关闭资源


//1.加载驱动

Class.forName("com.mysql.jdbc.Driver");



//2.创建连接

Connection conn = DriverManager.getConnection(url, user, password);



//3.执行sql语句并返回执行结果

//准备sql

String sql = "SELECT * FROM student";

 

//创建Statement,用PreparedStatement更好

//PreparedStatement stmt = conn.prepareStatement(sql);

Statement stmt = conn.createStatement();

 

//执行sql

ResultSet rs = stmt.executeQuery(sql);

 

//4.处理结果

while(rs.next()){

int id = rs.getInt("id");

String name = rs.getString("name");

String gender = rs.getString("gender");

System.out.println(id+","+name+","+gender);

}

 

//5.关闭资源

stmt.close();

conn.close();

 

3.JDBC中的ResultSet是指什么?

ResultSet是结果集,用来存放执行sql后返回的执行结果,对应于数据库中的数据表。

 

4.JDBC中,PreparedStatement相较于Statement有什么优点?

1)PreparedStatement可以使用预编译的sql,而Statment只能使用静态的sql

2)PreparedStatement可以使用sql缓存区,效率比Statment高

3)PreparedStatement可以有效防止sql注入,而Statment不能防止sql注入。

 

5. JDBC中如何进行事务处理?

答:一个事务是由一条或多条对数据库操作的
SQL语句所组成的一个不可分割的工作单元,只有当事务中的所有操作都正常执行了,整个事务才会被提交给数据库。在JDBC中,一般是通过commit()方法或rollback()方法来结束事务的操作。其中commit()方法表示完成对事务的提交,rollback()方法表示完成事务回滚,多用于在处理事务的过程中出现了异常的情况,这两种方法都位于java.sql.Connection类中。一般而言,事务默认操作是自动提交,即操作成功后,系统将自动调用commit()方法,否则将调用rollback()方法。

当然,在
JDBC中,也可以通过调用setAutoCommit(false)方法来禁止自动提交,然后就可以把多个数据库操作的表达式作为一个事务,在操作完成后调用commit()方法实现整体提交,如果其中一个表达式操作失败,就会抛出异常而不会调用commit()方法。在这种情况下,就可以在异常捕获的代码块中调用rollback()进行事务回滚。通过此种方法可以保持对数据库的多次操作后,数据仍然保持一致性。

 

6. 在进行数据库编程时,连接池有什么作用?

答:实际开发中“获得连接”或“释放资源”是非常消耗系统资源的两个过程,为了解决此类性能问题,通常情况我们采用连接池技术,来共享连接Connection。

用池来管理Connection,这样可以重复使用Connection。有了池,所以我们就不用自己来创建Connection,而是通过池来获取
Connection对象。当使用完Connection后,调用Connection的close()方法也不会真的关闭Connection,而是把
Connection“归还”给池。池就可以再利用这个Connection对象了。

 

常见的连接池有C3P0、DBCP。

 

C3P0开源免费的连接池!目前使用它的开源项目有:Spring、Hibernate等。使用第三方工具需要导入jar包,c3p0使用时还需要添加配置文件
c3p0-config.xml。

DBCP也是一个开源的连接池,是Apache Common成员之一,在企业开发中也比较常见,tomcat内置的连接池。

友情链接
KaDraw流程图
API参考文档
OK工具箱
云服务器优惠
阿里云优惠券
腾讯云优惠券
华为云优惠券
站点信息
问题反馈
邮箱:[email protected]
QQ群:637538335
关注微信