zoukankan      html  css  js  c++  java
  • Spring的JDBC框架概述

    以下内容引用自http://wiki.jikexueyuan.com/project/spring/jdbc-framework.html

    在使用普通的JDBC操作数据库时,就会很麻烦的写很多不必要的代码来处理异常,比如打开和关闭数据库连接等。但Spring JDBC框架负责所有的低层细节,从开始打开连接,准备和执行SQL语句,处理异常,处理事务,到最后关闭连接。

    所以当从数据库中获取数据时,你所做的是定义连接参数,指定要执行的SQL语句,每次迭代完成所需的工作。

    Spring JDBC提供了几种方法和相应的不同类与数据库的接口。我将要采用JdbcTemplate类的框架,它使用了最经典和最流行的方法。这是管理所有数据库通信和异常处理的中心框架类。

    JdbcTemplate类

    JDBC模板类执行SQL查询,更新语句,存储过程调用,在ResultSet上执行迭代,并提取返回的参数值。它还捕获JDBC异常,并将它们转换为org.springframework.dao包中定义的通用,更详细的异常层次结构。

    配置JdbcTemplate类的实例是线程安全的。因此,您可以配置JdbcTemplate的单个实例,然后将该共享引用安全地注入到多个DAO中。

    使用JDBC模板类时的常见做法是在Spring配置文件中配置DataSource,然后将共享DataSource bean的dependency-inject注入到DAO类中,并在DataSource的setter中创建JdbcTemplate。

    配置数据源

    使用MySql数据库在TEST数据库总创建Student表,脚本如下:

    CREATE TABLE Student(
       ID   INT NOT NULL AUTO_INCREMENT,
       NAME VARCHAR(20) NOT NULL,
       AGE  INT NOT NULL,
       PRIMARY KEY (ID)
    );

    现在我们需要向JDBC模板提供一个DataSource,因此它可以配置自己以获取数据库访问。可以使用一段代码在XML文件中配置DataSource,如下所示:

    <bean id = "dataSource" class = "org.springframework.jdbc.datasource.DriverManagerDataSource">
       <property name = "driverClassName" value = "com.mysql.jdbc.Driver"/>
       <property name = "url" value = "jdbc:mysql://localhost:3306/TEST"/>
       <property name = "username" value = "root"/>
       <property name = "password" value = "password"/>
    </bean>

    数据访问对象(DAO)

    DAO代表数据访问对象,它通常用于数据库交互。DAO提供读取和写入数据到数据库的方法,并且他们应该通过其他应用程序访问它们的接口来实现此功能。

    Spring中的DAO支持使用一致的方式轻松处理数据访问技术,如JDBC,Hibernate,JPA或JDO。

    执行SQL语句

    以下为使用SQL和JDBC Template对象对数据库表执行CRUD(创建,读取,更新和删除)操作。

    查询int类型

    String SQL = "select count(*) from Student";
    int rowCount = jdbcTemplateObject.queryForInt( SQL );

    查询long类型

    String SQL = "select count(*) from Student";
    long rowCount = jdbcTemplateObject.queryForLong( SQL );

    绑定变量的简单查询

    String SQL = "select age from Student where id = ?";
    int age = jdbcTemplateObject.queryForInt(SQL, new Object[]{10});

    查询字符串

    String SQL = "select name from Student where id = ?";
    String name = jdbcTemplateObject.queryForObject(SQL, new Object[]{10}, String.class);

    查询和返回一个对象

    String SQL = "select * from Student where id = ?";
    Student student = jdbcTemplateObject.queryForObject(SQL, new Object[]{10}, new StudentMapper());
    
    public class StudentMapper implements RowMapper<Student> {
       public Student mapRow(ResultSet rs, int rowNum) throws SQLException {
          Student student = new Student();
          student.setID(rs.getInt("id"));
          student.setName(rs.getString("name"));
          student.setAge(rs.getInt("age"));
          
          return student;
       }
    }

    查询并返回多个对象

    String SQL = "select * from Student";
    List<Student> students = jdbcTemplateObject.query(SQL, new StudentMapper());
    
    public class StudentMapper implements RowMapper<Student> {
       public Student mapRow(ResultSet rs, int rowNum) throws SQLException {
          Student student = new Student();
          student.setID(rs.getInt("id"));
          student.setName(rs.getString("name"));
          student.setAge(rs.getInt("age"));
          
          return student;
       }
    }

    在表中插入一行

    String SQL = "insert into Student (name, age) values (?, ?)";
    jdbcTemplateObject.update( SQL, new Object[]{"Zara", 11} );

    在表中更新一行

    String SQL = "update Student set name = ? where id = ?";
    jdbcTemplateObject.update( SQL, new Object[]{"Zara", 10} );

    从表中删除一行

    String SQL = "delete Student where id = ?";
    jdbcTemplateObject.update( SQL, new Object[]{20} );

    执行DDL语句

    可以使用jdbcTemplate中的execute(...)方法来执行任何SQL语句或DDL语句。以下是使用CREATE语句创建表的示例:

    String SQL = "CREATE TABLE Student( " +
       "ID   INT NOT NULL AUTO_INCREMENT, " +
       "NAME VARCHAR(20) NOT NULL, " +
       "AGE  INT NOT NULL, " +
       "PRIMARY KEY (ID));"
    
    jdbcTemplateObject.execute( SQL );
  • 相关阅读:
    winform编程设定listview选中行
    更新客户信息
    在Flutter中使用Android、iOS的原生 View
    怎么卸载nodejs?
    JavaScript实现简单的图片瀑布流插件
    通过代码重用攻击绕过现代XSS防御
    炫酷的播放粒子效果,你也可以学会!使用Web动画API制作
    14行实现js原生语法前端模板引擎
    什么是ESLint?
    js中require和import的区别
  • 原文地址:https://www.cnblogs.com/EasonJim/p/6906707.html
Copyright © 2011-2022 走看看