1.什么是JDBC?
JDBC: Java Database Connectivity 为多种关系型数据库提供统一访问。即通过Java代码访问和操作数据库
JDBC连接数据库的步骤
//JDBC的工具类代码,为持久层服务
package com.lkw.util;
import java.sql.*;
public class DBHelper {
/**
* <pre>
* JDBC驱动程序,默认为MySQL
* MySQL: <b>com.mysql.jdbc.Driver</b>
* MSSQLServer: <b>com.microsoft.sqlserver.jdbc.SQLServerDriver</b>
* </pre>
*/
private static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";
/**
* <pre>
* JDBC数据库URL,默认为MySQL
* MySQL:<b>jdbc:mysql://localhost:3306/数据库名</b>
* MSSQLServer:<b>jdbc:sqlserver://localhost:1433;DatabaseName=数据库名</b>
* </pre>
*/
private static final String JDBC_URL = "jdbc:mysql://localhost:3306/exam";
/**
* JDBC登录数据库服务器用户名和密码
*/
private static final String JDBC_USER = "root";
private static final String JDBC_PASSWORD = "root";
private static DBHelper db = null;
private static Connection conn = null;
private static PreparedStatement st = null;
static {
try {
//加载驱动程序
Class.forName(JDBC_DRIVER);
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
private DBHelper() throws SQLException {
//获取数据库连接
conn = DriverManager.getConnection(JDBC_URL, JDBC_USER, JDBC_PASSWORD);
}
//获取DBHelper对象
public static DBHelper getInstance() throws SQLException {
if(db == null || conn.isClosed()) {
db = new DBHelper();
}
return db;
}
//查询
public ResultSet executeQuery(String sql, Object...args) throws SQLException {
st = conn.prepareStatement(sql);//预处理
if(args != null && args.length > 0) {
for(int i = 0; i < args.length; ++i)
{
st.setObject(i + 1, args[i]);
}
}
return st.executeQuery();
}
//增删改
public int executeUpdate(String sql, Object...args) throws SQLException {
st = conn.prepareStatement(sql);
if(args != null && args.length > 0) {
for(int i = 0; i < args.length; ++i) {
st.setObject(i + 1, args[i]);
}
}
return st.executeUpdate();
}
/*关闭对象*/
public static void close() {
if(st != null ) {
try {
st.close();
} catch (SQLException e) {
e.printStackTrace();
}finally {
if(conn != null){
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}finally{
st = null;
conn = null;
db = null;
}
}
}
}
}
}
2. 简述JDBC的Resulset,与Connection类
ResultSet是结果集,用来存放执行sql后返回的执行结果,对应于数据库中的数据表
Connrction:与数据库连接的对象
3.JDBC中,PreparedStatement相较于Statement有什么优点?
1)PreparedStatement可以使用预编译的sql,而Statment只能使用静态的sql
2)PreparedStatement可以使用sql缓存区,效率比Statment高
3)PreparedStatement可以有效防止sql注入,而Statment不能防止sql注入。
4.JDBC中如何进行事务处理?
一个事务是由一条或多条对数据库操作的SQL语句所组成的一个不可分割的工作单元,只有当事务中的所有操作都正常执行了,整个事务才会被提交给数据库。在JDBC中,一般是通过commit()方法或rollback()方法来结束事务的操作。其中commit()方法表示完成对事务的提交,rollback()方法表示完成事务回滚,多用于在处理事务的过程中出现了异常的情况,这两种方法都位于java.sql.Connection类中。一般而言,事务默认操作是自动提交,即操作成功后,系统将自动调用commit()方法,否则将调用rollback()方法。
当然,在JDBC中,也可以通过调用setAutoCommit(false)方法来禁止自动提交,然后就可以把多个数据库操作的表达式作为一个事务,在操作完成后调用commit()方法实现整体提交,如果其中一个表达式操作失败,就会抛出异常而不会调用commit()方法。在这种情况下,就可以在异常捕获的代码块中调用rollback()进行事务回滚。通过此种方法可以保持对数据库的多次操作后,数据仍然保持一致性。
JDBC事务处理的方法
try{
con.setAutoCommit(false);//开启事务
......
con.commit();//try的最后提交事务
} catch() {
con.rollback();//回滚事务
}
5.在进行数据库编程时,连接池有什么作用?
实际开发中“获得连接”或“释放资源”是非常消耗系统资源的两个过程,为了解决此类性能问题,通常情况我们采用连接池技术,来共享连接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内置的连接池。
本文介绍了JDBC(Java Database Connectivity),它为多种关系型数据库提供统一访问。阐述了JDBC连接数据库的步骤,简述了ResultSet和Connection类,对比了PreparedStatement和Statement的优缺点,说明了JDBC中事务处理的方法,还介绍了数据库编程中连接池的作用及常见连接池。
5178

被折叠的 条评论
为什么被折叠?



