一开始学的是SSH框架,所以与数据库之间的操作都是有hibernate来完成的,现在了解了一些springJDBC发现原来spring框架已经把jdbc做了封装。不需要使用hibernate而仅用spring框架就可以完成数据库的增删改查操作了。下面就我初步springJDBC做一些简单的介绍:

(但是还是没有弄明白springJDBC相对于hibernate而言有什么优势。。。)

springJDBC的核心就是JdbcTemplate这个类,同个这个类我们可以很简单的完成对数据库的增删改查,省去了建立数据库连接Connection、预编译sql语句PrepareSatement及关闭释放数据库资源,只需要创建sql语句和接收处理结果。

代码由两部分构成:业务逻辑部门和和spring相关的XML部分

一、业务逻辑部分:

package com.wd.dao;

import org.springframework.jdbc.core.JdbcTemplate;

public class DeptDao {

private JdbcTemplate jdbcTemplate;

public JdbcTemplate getJdbcTemplate() {

return jdbcTemplate;

}

public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {

this.jdbcTemplate = jdbcTemplate;

}

        public List findAll(){

String sql = "select * from dept";

return jdbcTemplate.queryForList(sql);

}

/*****************************************

* 查询

* @return

*/

public List<Dept> findAllDepts(){

List<Dept> depts = new ArrayList<Dept>();

String sql = "select * from dept where DEPTNAME = ?";

List list = jdbcTemplate.queryForList(sql, new Object[]{"htxx"});

Iterator iterator = list.iterator();

Dept dept = null;

while(iterator.hasNext()){

Map deptsMap = (Map)iterator.next();

dept = new Dept();

dept.setDeptSno(Integer.parseInt(deptsMap.get("DEPTSNO").toString()));

dept.setDeptName(deptsMap.get("DEPTNAME").toString());

dept.setLoc(deptsMap.get("LOC").toString());

depts.add(dept);

}

return depts;

}

/******************************************

* 删除

* @param deptSno

* @return

*/

public int delete(int deptSno){

String sql = "delete from dept where DEPTSNO = ?";

return jdbcTemplate.update(sql, new Object[]{deptSno});

}

/*******************************************

* 插入

* @param dept

* @return

* @throws UnsupportedEncodingException

*/

public int insert(Dept dept) throws UnsupportedEncodingException{

String sql = "insert into dept values(?,?,?)";

return jdbcTemplate.update(sql, 

                                           new Object[]{dept.getDeptSno(), dept.getDeptName(),

dept.getLoc()});

}

/*******************************************

* 批量插入

* @param paramsList

*/

public int[] batchInsert(final List<Dept> paramsList){

String sql = "insert into dept values(?,?,?)";

return jdbcTemplate.batchUpdate(sql, new BatchPreparedStatementSetter() {

@Override

public void setValues(PreparedStatement ps, int i) throws SQLException {

Dept dept = paramsList.get(i);

ps.setInt(1, dept.getDeptSno());

ps.setString(2, dept.getDeptName());

ps.setString(3, dept.getLoc());

}

@Override

public int getBatchSize() {

return paramsList.size();

}

});

}

}

二、applicationContext.xml配置,包括连接数据库信息dataSource、Template、dao

wKiom1XAJ7uz7IxUAAUCvHUkHUY445.jpg

然后写一个测试代码进行测试:

public static void main(String[] args) {

ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml");

DeptDao deptDao = (DeptDao)ac.getBean("deptDao");

                //以插入单条数据为例

                Dept dept = new Dept();

dept.setDeptSno(120);

dept.setDeptName("htxx");

dept.setLoc("NO.18");

int row;

try {

row = deptDao.insert(dept);

System.out.println("row = "+row);

} catch (UnsupportedEncodingException e) {

e.printStackTrace();

}

}

另外springJDBC中还有一些此处未提到的方法,我个人觉得只要搞明白了如何成功完成springJDBC的配置,使其能够和数据库连接成功,其他的都好说,毕竟人家已经给你定义好方法了,只需要传入正确的参数来调用就行了。