Spring JDBC

来源:互联网 发布:php 判断域名 编辑:程序博客网 时间:2024/04/20 05:44

Spring jdbc


  Spring将替我们完成所有使用JDBC API进行开发的单调乏味的、底层细节处理工作。
  操作JDBC时Spring可以帮我们做这些事情:
  定义数据库连接参数,打开数据库连接,处理异常,关闭数据库连接
  我们仅需要关注:
  声明SQL语句,处理每一次得到的结果.

一个较为简单的例子与讲解

JdbcTemplate类

JdbcTemplate是core包的核心类。它替我们完成了资源的创建以及释放工作,从而简化了我们对JDBC的使用。它还可以帮助我们避免一些常见的错误,比如忘记关闭数据库连接。JdbcTemplate将完成JDBC核心处理流程,比如SQL语句的创建、执行,而把SQL语句的生成以及查询结果的提取工作留给我们的应用代码。它可以完成SQL查询、更新以及调用存储过程,可以对ResultSet进行遍历并加以提取。它还可以捕获JDBC异常并将其转换成org.springframework.dao包中定义的,通用的,信息更丰富的异常。

代码分为三部分
第一部是利用Spring处理业务,第二部分创建Spring相关的XML,第三部分将XML和Context结合到一起。

package com.jiaozg.dao;import java.math.BigDecimal;import java.util.ArrayList;import java.util.Iterator;import java.util.List;import java.util.Map;import org.springframework.jdbc.core.JdbcTemplate;import com.jiaozg.model.Dept;import com.jiaozg.util.SpringUtil;主要类:  public class DeptDao {    private JdbcTemplate jdbcT;    public void setJdbcT(JdbcTemplate jdbcT) {        this.jdbcT = jdbcT;    }    public  List findALL() {        String sql = "select * from dept";        return jdbcT.queryForList(sql);    }    public List<Dept> findALLDepts() {        List<Dept> depts = new ArrayList<Dept>();;        String sql = "select * from Dept";        List list = jdbcT.queryForList(sql);         Iterator iterator = list.iterator();        Dept dept = null;        while (iterator.hasNext()) {            Map map4dept = (Map) iterator.next();            dept = new Dept();                   dept.setDeptNo(((BigDecimal) map4dept.get("DEPTNO")).intValue());            dept.setDName((String)map4dept.get("DNAME"));            dept.setLoc((String)map4dept.get("LOC"));                    depts.add(dept);        }        return depts;    }        public int delete(int bid){        String sql = "delete from DeptInfo where bid =?";        return jdbcT.update(sql, new Object[]{bid});    }         public static void main(String[] args) {              DeptDao dao = (DeptDao) SpringUtil.getBean("deptDao");        List<Dept> depts = dao.findALLDepts();;        for(Dept dept:depts){            System.out.println(dept.getDeptNo()+","+dept.getDName()+","+dept.getLoc());        }        System.out.println("---------------------------------");        List list = dao.findALL();        for(Iterator it = list.iterator(); it.hasNext(); ) {            System.out.println(it.next());        }    }}

public class SpringUtil { private static ApplicationContext  ctx = new ClassPathXmlApplicationContext("applicationContext.xml");    public static Object getBean(String beanName){         return ctx.getBean(beanName);    }    }

<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">    <bean id="springDSN"        class="org.springframework.jdbc.datasource.DriverManagerDataSource">        <property name="driverClassName"            value="oracle.jdbc.driver.OracleDriver">        </property>        <property name="url"            value="jdbc:oracle:thin:@127.0.0.1:1521:orcl">        </property>        <property name="username" value="scott"></property>        <property name="password" value="Qwer1234"></property>    </bean>    <bean id="jdbcTemplate"        class="org.springframework.jdbc.core.JdbcTemplate" abstract="false"        lazy-init="false" autowire="default" dependency-check="default">        <property name="dataSource">            <ref bean="springDSN" />        </property>    </bean>    <bean id="deptDao" class="com.jiaozg.dao.DeptDao">       <property name="jdbcT">          <ref bean="jdbcTemplate" />       </property>    </bean></beans>

总结:

JAVA第一部分是一个dao层的类,首先注入了jdbcTemplate,接下来写了三个数据库操作方法
JAVA第二部分是一个读取applicationContext.xml配置的类,并获得bean
XML部分:XML第一部分是配置到数据库的连接信息,第二部分将第一部分定义的数据库连接信息传递给jdbcTemplate类,并且将jdbcTemplate类交给Spring管理,第三部分往DeptDao注入jdbcTemplate Bean

0 0