import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class JDBC_Test2 {
public static void main(String[] args) {
Connection conn=null;
Statement st=null;
ResultSet rs=null;
String url="jdbc:mysql://localhost:3306/webexample?useUnicode=true&characterEncoding=UTF-8";
String userName="root";
String passWord="";
try {
Class.forName("com.mysql.jdbc.Driver");
conn=DriverManager.getConnection(url,userName,passWord);
st=conn.createStatement();
rs=st.executeQuery("select * from admininfo");
while (rs.next()) {
System.out.println(rs.getString("Aname"));
}
} catch (ClassNotFoundException e) {
e.printStackTrace(); //log4j 具体记录
}catch (SQLException e) {
e.printStackTrace();
}
finally{
try {
if (rs!=null) {
rs.close();
rs=null;
}
if (st!=null) {
st.close();
st=null;
}
if (conn!=null) {
conn.close();
conn=null;
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
我假定朋友们都有一定的编码经验,那么大家再看了最基本的jdbc后,心里应该会有两个想法
package templatemethod1;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public abstract class JDBCTemplate {
public Object execute(String sql) {
String url="";
String userName="";
String password="";
Connection con=null;
Statement st=null;
ResultSet rs=null;
try{
Class.forName("com.mysql.jdbc.driver");
con=DriverManager.getConnection(url,userName,password);
st=con.createStatement();
rs=st.executeQuery(sql);
//只把核心的第五步 抽象出来 交给子类处理
Object object=doResultSet(rs);
return object;
}
catch (ClassNotFoundException e){
e.printStackTrace();
}
catch(SQLException e){
e.printStackTrace();
}
finally{
try{
if(rs!=null){
rs.close();
rs=null;
}
//...
}catch(SQLException e){
e.printStackTrace();
}
}
return null;
}
//抽象出来 交给子类处理
public abstract Object doResultSet(ResultSet rs);
}
package templatemethod1;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import model.Student;
public class JDBCTemplateStudentImpl extends JDBCTemplate {
//doResultSet 就是关于获取Student的真正核心的代码
@Override
public Object doResultSet(ResultSet rs) {
List userList = new ArrayList();
try {
Student student = null;
while (rs.next()) {
student = new Student();
student.setId(rs.getInt("id"));
student.setBirth(rs.getDate("birth"));
userList.add(student);
}
return userList;
} catch (SQLException e) {
e.printStackTrace();
return null;
}
}
}
最后的测试代码
package templatemethod1;
import java.util.List;
import model.Student;
public class TemplateMethodTest {
public static void main(String[] args) {
String sql="select * from user";
JDBCTemplate template=new JDBCTemplateStudentImpl();
List students=(List) template.execute(sql);
}
}
package templatemethod2;
import java.sql.SQLException;
import java.sql.Statement;
public interface StatementCallback {
//这个doInStatement相当于上面的doResultSet
Object doInStatement(Statement stmt) throws SQLException;
}
package templatemethod2;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class JDBCTemplate {
public Object execute(StatementCallback action) {
String url="";
String userName="";
String password="";
Connection con=null;
Statement st=null;
ResultSet rs=null;
try{
Class.forName("com.mysql.jdbc.driver");
con=DriverManager.getConnection(url,userName,password);
st=con.createStatement();
Object object=action.doInStatement(st);
return object;
}
//省略try catch
return null;
}
public Object query(StatementCallback action){
return execute(action);
}
}
下面的测试方法,只要给定一个sql,就能传回List
@SuppressWarnings("unchecked")
public List test2(final String sql) {
JDBCTemplate jdbcTemplate = new JDBCTemplate();
return (List) jdbcTemplate.execute(new StatementCallback() {
@Override
public Object doInStatement(Statement stmt) throws SQLException {
ResultSet rs = stmt.executeQuery(sql);
List userList = new ArrayList();
Student user = null;
while (rs.next()) {
user = new Student();
user.setId(rs.getInt("id"));
user.setBirth(rs.getDate("birth"));
userList.add(user);
}
return userList;
}
});
}