学习链接地址:http://www.iteye.com/blogs/subjects/spring3
第一部分 传统JDBC
@Test
public void test() throws Exception {
Connection conn = null;
PreparedStatement pstmt = null;
try {
conn = getConnection(); //1.获取JDBC连接
//2.声明SQL
String sql = "select * from INFORMATION_SCHEMA.SYSTEM_TABLES";
pstmt = conn.prepareStatement(sql); //3.预编译SQL
ResultSet rs = pstmt.executeQuery(); //4.执行SQL
process(rs); //5.处理结果集
closeResultSet(rs); //5.释放结果集
closeStatement(pstmt); //6.释放Statement
conn.commit(); //8.提交事务
} catch (Exception e) {
//9.处理异常并回滚事务
conn.rollback();
throw e;
} finally {
//10.释放JDBC连接,防止JDBC连接不关闭造成的内存泄漏
closeConnection(conn);
}
}
第二部分 Spring的JDBC架构
第三部分 JDBC模板类
jdbc:oracle:thin:@localhost:1521:bjpowernode
jdbc:mysql://localhost:3306/imooc
import java.sql.ResultSet;
import java.sql.SQLException;
import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.Test;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowCallbackHandler;
import org.springframework.jdbc.datasource.DriverManagerDataSource;
public class JdbcTemplateTest {
private static JdbcTemplate jdbcTemplate;
@BeforeClass
public static void setUpClass() {
String url = "jdbc:hsqldb:mem:test";
String username = "sa";
String password = "";
DriverManagerDataSource dataSource = new DriverManagerDataSource(url, username, password);
dataSource.setDriverClassName("org.hsqldb.jdbcDriver");
jdbcTemplate = new JdbcTemplate(dataSource);
}
@Test
public void test() {
//1.声明SQL
String sql = "select * from INFORMATION_SCHEMA.SYSTEM_TABLES";
jdbcTemplate.query(sql, new RowCallbackHandler() {
@Override
public void processRow(ResultSet rs) throws SQLException {
//2.处理结果集
String value = rs.getString("TABLE_NAME");
System.out.println("Column TABLENAME:" + value);
}
});
}
}