使用Spring JDBCTemplate简化JDBC的操作

接触过JAVA WEB开发的朋友肯定都知道Hibernate框架,虽然不否定它的强大之处,但个人对它一直无感,总感觉不够灵活,太过臃肿了。

今天来说下Spring中关于JDBC的一个辅助类(JDBC Template),它封装了JDBC的操作,使用起来非常方便。

 

先说下"傻瓜式"的使用(不依赖于xml配置):

直接写个测试单元:

 1 package com.lcw.spring.jdbc;
 2 
 3 import org.junit.Test;
 4  org.springframework.jdbc.core.JdbcTemplate;
 5  org.springframework.jdbc.datasource.DriverManagerDataSource;
 6 
 7 public class JDBCTemplate {
 8     
 9     @Test
10     void demo(){
11         DriverManagerDataSource dataSource=new DriverManagerDataSource();
12         dataSource.setDriverClassName("com.mysql.jdbc.Driver");
13         dataSource.setUrl("jdbc:mysql:///spring"14         dataSource.setUsername("root"15         dataSource.setPassword(""16         
17         JdbcTemplate jdbcTemplate= JdbcTemplate(dataSource);
18         jdbcTemplate.execute("create table temp(id int primary key,name varchar(32))"19     
20     }
21 
22 }

 

很简单吧,再来看下使用结合配置文件,完整的实现对一个类的增删改查

首先DEMO目录结构:

appliactionContext.xml

<?xml version="1.0" encoding="UTF-8"?>
 2 <beans xmlns="http://www.springframework.org/schema/beans"
 3        xmlns:p="http://www.springframework.org/schema/p"
 4        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 5        xsi:schemaLocation="
 6 http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
 7     
 8     <!--数据源的配置 -->
 9     bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"10         property name="driverClassName" value="com.mysql.jdbc.Driver"></property11         ="url"="jdbc:mysql:///spring"12         ="username"="root"13         ="password"=""14     </bean15     
16     
17   
18     ="jdbcTemplate"="org.springframework.jdbc.core.JdbcTemplate"19          ref="dataSource"20     21     
22     
23     ="userDao"="com.curd.spring.impl.UserDAOImpl"24         ="jdbcTemplate"25     26 
27 
28 
29 beans>

接口:IUserDAO.java

 com.curd.spring.dao;
 java.util.List;
 4 
 com.curd.spring.vo.User;
interface IUserDAO {
 8 
 addUser(User user);
10 
11     void deleteUser(int id);
12 
13      updateUser(User user);
14 
15     public String searchUserName(17     public User searchUser(18     
19     public List<User> findAll();
20 
21 }

 

接口实现类:UserDAOImpl.java

按照以往Spring的依赖注入,我们需要在接口实现类中利用构造器去获取JdbcTemplate

Spring早就帮我们想到了这点,它为我们提供了JdbcDaoSupport支持类,所有DAO继承这个类,就会自动获得JdbcTemplate(前提是注入DataSource)。

1     2         3     4     
5     
6     7         8     >

在我们的实现类中直接利用getJdbcTemplate就可以获取操作对象了。

JdbcTemplate主要提供下列方法:

  1、execute方法:可以用于执行任何SQL语句,一般用于执行DDL语句;

  2、update方法及batchUpdate方法:update方法用于执行新增、修改、删除等语句;batchUpdate方法用于执行批处理相关语句;

  3、query方法及queryForXXX方法:用于执行查询相关语句;

  4、call方法:用于执行存储过程、函数相关语句。

 com.curd.spring.impl;
 java.sql.ResultSet;
 java.sql.SQLException;
 org.springframework.jdbc.core.RowMapper;
 8  org.springframework.jdbc.core.support.JdbcDaoSupport;
 com.curd.spring.dao.IUserDAO;
10 11 
12 class UserDAOImpl extends JdbcDaoSupport implements13 
 addUser(User user) {
15         String sql = "insert into user values(?,?,?)";
16         this.getJdbcTemplate().update(sql,user.getId(),user.getUsername(),17                 user.getPassword());
18 19 
 id) {
21         String sql = "delete from user where id=?"22         23 
24 25 
26      updateUser(User user) {
27         String sql = "update user set username=?,password=? where id=?"28                         user.getPassword(),user.getId());
30 31 
32     int id) {// 简单查询,按照ID查询,返回字符串
33         String sql = "select username from user where id=?"34          返回类型为String(String.class)
35         return this.getJdbcTemplate().queryForObject(sql,String.,1)">36 
37 38 
39     public List<User> findAll() { 复杂查询返回List集合
40         String sql = "select * from user"41         this.getJdbcTemplate().query(sql, UserRowMapper());
42 
43 44 
45     46         String sql="select * from user where id=?"47          UserRowMapper(),1)">48 49 
50     class UserRowMapper implements RowMapper<User> {
51      //rs为返回结果集,以每行为单位封装着
52         public User mapRow(ResultSet rs,1)">int rowNum) throws SQLException {
53     
54             User user =  User();
55             user.setId(rs.getInt("id"));
56             user.setUsername(rs.getString("username"57             user.setPassword(rs.getString("password"58             return user;
59         }
60 
61 62 
63 }

测试类:UserTest.java

 com.curd.spring.test;
 org.springframework.context.ApplicationContext;
 org.springframework.context.support.ClassPathXmlApplicationContext;
 UserTest {
13     
14     @Test
 demo1(){
16         User user=17         user.setId(318         user.setUsername("admin"19         user.setPassword("123456"20         
21         ApplicationContext applicationContext=new ClassPathXmlApplicationContext("applicationContext.xml"22         IUserDAO dao=(IUserDAO) applicationContext.getBean("userDao"23         dao.addUser(user);
24         
25 26     
27     @Test
28      demo2(){
29         User user=30         user.setId(131         user.setUsername("admin"32         user.setPassword("admin"33         
34         ApplicationContext applicationContext=35         IUserDAO dao=(IUserDAO) applicationContext.getBean("userDao"36         dao.updateUser(user);
38     
39     @Test
40      demo3(){
41         ApplicationContext applicationContext=42         IUserDAO dao=(IUserDAO) applicationContext.getBean("userDao"43         dao.deleteUser(344 45     
46     @Test查(简单查询,返回字符串)
47      demo4(){
48         ApplicationContext applicationContext=49         IUserDAO dao=(IUserDAO) applicationContext.getBean("userDao"50         String name=dao.searchUserName(151         System.out.println(name);
52 54     @Test查(简单查询,返回对象)
55      demo5(){
56         ApplicationContext applicationContext=57         IUserDAO dao=(IUserDAO) applicationContext.getBean("userDao"58         User user=dao.searchUser(1        System.out.println(user.getUsername());
60 61     
62     @Test查(复杂查询,返回对象集合)
63      demo6(){
64         ApplicationContext applicationContext=65         IUserDAO dao=(IUserDAO) applicationContext.getBean("userDao"66         List<User> users=dao.findAll();
67         System.out.println(users.size());
68 69     
70     
71 
72 }

怎么样,很简单吧,在不缺JDBC里SQL的灵活操作又去除了繁杂操作~

 

附:

1、Spring 为每种持久化技术 提供一个支持类,在DAO 中注入 模板工具类
    (1)JDBC : org.springframework.jdbc.core.support.JdbcDaoSupport
    (2)Hibernate 3.0 :org.springframework.orm.hibernate3.support.HibernateDaoSupport
    (3)iBatis :org.springframework.orm.ibatis.support.SqlMapClientDaoSupport

用户自己编写DAO 只需要继承 JdbcDaoSupport, 就可以注入 JdbcTemplate

2、 通过jdbcTemplate 提供 int update(String sql,Object... args) 实现增加 、修改 、删除

 

3、简单查询,返回原始数据类型, String类型
String sql = "select count(*) from user"; // int queryForInt(String sql)
String sql = "select name from user where id = ? "; // <T> T queryForObject(String sql,Class<T> requiredType,Object... args)

 

4、 复杂查询
JdbcTemplate 没有handler, 手动完成对象封装

编写实体类 RowMapper
class UserRowMapper implements RowMapper<User> {
  @Override
  public User mapRow(ResultSet rs,int rowNum) throws SQLException {
    // rs 已经指向每一条数据,不需要自己调用 next,将rs指向数据 转换 User对象
    User user = new User();
    user.setId(rs.getInt("id"));
    user.setName(rs.getString("name"));
    return user;
  }
}

查询单个对象 <T> T queryForObject(String sql,RowMapper<T> rowMapper,Object... args)
return this.getJdbcTemplate().queryForObject(sql,new UserRowMapper(),id);

查询所有对象List集合 <T> List<T> query(String sql,Object... args)
return this.getJdbcTemplate().query(sql,new UserRowMapper());

 

以上提供的方法基本可以满足我们的日常需要了。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


开发过程中是不可避免地会出现各种异常情况的,例如网络连接异常、数据格式异常、空指针异常等等。异常的出现可能导致程序的运行出现问题,甚至直接导致程序崩溃。因此,在开发过程中,合理处理异常、避免异常产生、以及对异常进行有效的调试是非常重要的。 对于异常的处理,一般分为两种方式: 编程式异常处理:是指在代
说明:使用注解方式实现AOP切面。 什么是AOP? 面向切面编程,利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。 通俗描述:不通过修改源代码方式,在主干功能里面添加新功能。 AOP底层使用动态代理。 AOP术语 连接点
Spring MVC中的拦截器是一种可以在请求处理过程中对请求进行拦截和处理的机制。 拦截器可以用于执行一些公共的操作,例如日志记录、权限验证、数据转换等。在Spring MVC中,可以通过实现HandlerInterceptor接口来创建自定义的拦截器,并通过配置来指定拦截器的应用范围和顺序。 S
在 JavaWeb 中,共享域指的是在 Servlet 中存储数据,以便在同一 Web 应用程序的多个组件中进行共享和访问。常见的共享域有四种:ServletContext、HttpSession、HttpServletRequest、PageContext。 ServletContext 共享域:
文件上传 说明: 使用maven构建web工程。 使用Thymeleaf技术进行服务器页面渲染。 使用ResponseEntity实现下载文件的功能。 @Controller public class FileDownloadAndUpload { @GetMapping(&quot;/file/d
创建初始化类,替换web.xml 在Servlet3.0环境中,Web容器(Tomcat)会在类路径中查找实现javax.servlet.ServletContainerInitializer接口的类,如果找到的话就用它来配置Servlet容器。 Spring提供了这个接口的实现,名为SpringS
在 Web 应用的三层架构中,确保在表述层(Presentation Layer)对数据进行检查和校验是非常重要的。正确的数据校验可以确保业务逻辑层(Business Logic Layer)基于有效和合法的数据进行处理,同时将错误的数据隔离在业务逻辑层之外。这有助于提高系统的健壮性、安全性和可维护
什么是事务? 事务(Transaction)是数据库操作最基本单元,逻辑上一组操作,要么都成功,要么都失败,如果操作之间有一个失败所有操作都失败 。 事务四个特性(ACID) 原子性 一组操作要么都成功,要么都失败。 一致性 一组数据从事务1合法状态转为事务2的另一种合法状态,就是一致。 隔离性 事
什么是JdbcTemplate? Spring 框架对 JDBC 进行封装,使用 JdbcTemplate 方便实现对数据库操作。 准备工作 引入jdbcTemplate的相关依赖: 案例实操 创建jdbc.properties文件,配置数据库信息 jdbc.driver=com.mysql.cj.
SpringMVC1.MVC架构MVC是模型(Model)、视图(View)、控制器(Controller)的简写,是一种软件设计规范是将业务逻辑、数据、显示分离的方法来写代码MVC主要作用是:降低了视图和业务逻辑之间的双向耦合MVC是一个架构模型,不是一种设计模式。1.model(模型)数据模型,提供要展示的数据,因此包
SpringMVC学习笔记1.SpringMVC应用1.1SpringMVC简介​SpringMVC全名叫SpringWebMVC,是⼀种基于Java的实现MVC设计模型的请求驱动类型的轻量级Web框架,属于SpringFrameWork的后续产品。​MVC全名是ModelViewController,是模型(model)-视图(view)-控制器(co
11.1数据回显基本用法数据回显就是当用户数据提交失败时,自动填充好已经输入的数据。一般来说,如果使用Ajax来做数据提交,基本上是没有数据回显这个需求的,但是如果是通过表单做数据提交,那么数据回显就非常有必要了。11.1.1简单数据类型简单数据类型,实际上框架在这里没有
一、SpringMVC简介1、SpringMVC中重要组件DispatcherServlet:前端控制器,接收所有请求(如果配置/不包含jsp)HandlerMapping:解析请求格式的.判断希望要执行哪个具体的方法.HandlerAdapter:负责调用具体的方法.ViewResovler:视图解析器.解析结果,准备跳转到具体的物
1.它们主要负责的模块Spring主要应用于业务逻辑层。SpringMVC主要应用于表现层。MyBatis主要应用于持久层。2.它们的核心Spring有三大核心,分别是IOC(控制反转),DI(依赖注入)和AOP(面向切面编程)。SpringMVC的核心是DispatcherServlet(前端控制器)。MyBatis的核心是ORM(对
3.注解开发Springmvc1.使用注解开发要注意开启注解支持,2.注解简化了,处理映射器和处理适配器,只用去管视图解析器即可案例代码:1.web.xml,基本不变可以直接拿去用<!--调用DispatcherServlet--><servlet><servlet-name>springmvc</servlet-name>
拦截器概述SpringMVC的处理器拦截器类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理。开发者可以自己定义一些拦截器来实现特定的功能。**过滤器与拦截器的区别:**拦截器是AOP思想的具体应用。过滤器servlet规范中的一部分,任何javaweb工程都可以使用
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:context="http://www.springframework.org/schema/context"xmlns:mvc="http://www.springframework.org/schema/mvc"xmlns:xsi="
学习内容:1、SSH&SSM2、Spring3、Struts2&SpringMVC4、Hibernate&MyBatis学习产出:1.SSH和SSM都是有Spring框架的,他们两个差不多。2.Spring分为四个模块,持久层,表示层,检测层,还有核心层,核心层分为2个关键核心功能。分别为,控制反转(IOC),依赖注入(DI),和面向切面编程
一、SpringMVC项目无法引入js,css的问题具体原因是css和js等被SpringMVC拦截了:解决方案:在spring-mvc.xml中配置<mvc:default-servlet-handler/><?xmlversion="1.0"encoding="UTF-8"?><beansxmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
开发环境:Eclipse/MyEclipse、Tomcat8、Jdk1.8数据库:MySQL前端:JavaScript、jQuery、bootstrap4、particles.js后端:maven、SpringMVC、MyBatis、ajax、mysql读写分离、mybatis分页适用于:课程设计,毕业设计,学习等等系统介绍