[转] SpringJdbc的几种不同的用法
转自:http://vsp.iteye.com/blog/1182887
Spring对jdbc做了良好的封装,本人在学习时做了以下几种方式的尝试
首页先来创建一个dao接口
- package com.wys.dao;
- public interface IUserDao {
- void save();
- }
第一种方式通过继承JdbcDaoSupport来获取JdbcTemplate,需要注入JdbcTemplate
- package com.wys.dao.impl;
- import java.util.Map;
- import org.springframework.jdbc.core.support.JdbcDaoSupport;
- import com.wys.dao.IUserDao;
- public class UserDaoImpl extends JdbcDaoSupport implements IUserDao {
- @Override
- public void save() {
- String sql = "**********";
- Map<String,?> map = this.getJdbcTemplate().queryForMap(sql);
- System.out.println("成功!");
- }
- }
配置文件如下:
- <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
- <property name="dataSource" ref="dataSource" />
- </bean>
- <bean id="userImpDao" class="com.wys.dao.impl.UserDaoImpl">
- <property name="jdbcTemplate" ref="jdbcTemplate" />
- </bean>
JdbcTemplate提供了众多的对数据库操作的方法
第二种方法是组合JdbcTemplate,因为JdbcTemplate的创建需要注入DataSource,所以这里只需要直接注入DataSource就可以
- package com.wys.dao.impl;
- import java.util.Map;
- import javax.sql.DataSource;
- import org.springframework.context.ApplicationContext;
- import org.springframework.context.support.ClassPathXmlApplicationContext;
- import org.springframework.jdbc.core.JdbcTemplate;
- import org.springframework.jdbc.core.simple.SimpleJdbcTemplate;
- import org.springframework.jdbc.core.support.JdbcDaoSupport;
- import com.wys.dao.IUserDao;
- public class UserDao2Impl implements IUserDao {
- private JdbcTemplate jdbcTemplate;
- @Override
- public void save() {
- String sql = "******";
- Map<String,?> map = this.jdbcTemplate.queryForMap(sql);
- System.out.println("成功!");
- }
- //注入DataSource
- public void setDataSource(DataSource dataSource) {
- jdbcTemplate = new JdbcTemplate(dataSource);
- }
- }
配置文件
- <bean id="userImpl2Dao" class="com.wys.dao.impl.UserDao2Impl">
- <property name="dataSource" ref="dataSource" />
- </bean>
第三种方法是继承SimpleJdbcDaoSupport,通过SimpleJdbcDaoSupport可以获取SimpleJdbcTemplate,SimpleJdbcTemplate里也提供了大量的操作数据库的方法,因为SimpleJdbcDaoSupport继承了JdbcDaoSupport,所有可以获得JdbcTemplate,JdbcTemplate相对SimpleJdbcTemplate提供了更多和更高级的一些操作的方法,根据需要来使用,这里只需要直接注入JdbcTemplate,因为SimpleJdbcTemplate是通过JdbcTemplate来创建的
- package com.wys.dao.impl;
- import java.util.Map;
- import javax.sql.DataSource;
- import org.springframework.context.ApplicationContext;
- import org.springframework.context.support.ClassPathXmlApplicationContext;
- import org.springframework.jdbc.core.simple.SimpleJdbcDaoSupport;
- import org.springframework.jdbc.core.simple.SimpleJdbcTemplate;
- import org.springframework.jdbc.core.support.JdbcDaoSupport;
- import com.wys.dao.IUserDao;
- public class UserDao3Impl extends SimpleJdbcDaoSupport implements IUserDao {
- @Override
- public void save() {
- String sql = "***";
- Map<String,Object> map = this.getSimpleJdbcTemplate().queryForMap(sql);//SimpleJdbcTemplate
- Map<String,Object> map2 = this.getJdbcTemplate().queryForMap(sql);//JdbcTemplate
- System.out.println("成功!");
- }
- }
配置如下:
- <bean id="userImpl3Dao" class="com.wys.dao.impl.UserDao3Impl">
- <property name="jdbcTemplate" ref="jdbcTemplate" />
- </bean>
第四种直接组合SimpleJdbcTemplate,因为SimpleJdbcTemplate的创建是需要DataSource的,所以需要注入DataSource
- package com.wys.dao.impl;
- import java.util.Map;
- import javax.sql.DataSource;
- import org.springframework.context.ApplicationContext;
- import org.springframework.context.support.ClassPathXmlApplicationContext;
- import org.springframework.jdbc.core.JdbcTemplate;
- import org.springframework.jdbc.core.simple.SimpleJdbcTemplate;
- import org.springframework.jdbc.core.support.JdbcDaoSupport;
- import com.wys.dao.IUserDao;
- public class UserDao4Impl implements IUserDao {
- private SimpleJdbcTemplate jdbcTemplate;
- @Override
- public void save() {
- String sql = "******";
- Map<String,?> map = this.jdbcTemplate.queryForMap(sql);
- System.out.println("成功!");
- }
- public void setDataSource(DataSource dataSource) {
- jdbcTemplate = new SimpleJdbcTemplate(dataSource);
- }
- }
配置文件:
- <bean id="userImpl4Dao" class="com.wys.dao.impl.UserDao4Impl">
- <property name="dataSource" ref="dataSource" />
- </bean>
第五种方法也是组全JdbcTemplate,直接注入JdbcTemplate,而不是DataSource ,因为在JdbcTemplate中已经注入了DataSource
- package com.wys.dao.impl;
- import java.util.Map;
- import javax.sql.DataSource;
- import org.springframework.context.ApplicationContext;
- import org.springframework.context.support.ClassPathXmlApplicationContext;
- import org.springframework.jdbc.core.JdbcTemplate;
- import org.springframework.jdbc.core.simple.SimpleJdbcTemplate;
- import org.springframework.jdbc.core.support.JdbcDaoSupport;
- import com.wys.dao.IUserDao;
- public class UserDao5Impl implements IUserDao {
- private JdbcTemplate jdbcTemplate;
- public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
- this.jdbcTemplate = jdbcTemplate;
- }
- @Override
- public void save() {
- String sql = "*****";
- Map<String,?> map = this.jdbcTemplate.queryForMap(sql);
- System.out.println("成功!");
- }
- }
配置如下
- <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
- <property name="dataSource" ref="dataSource" />
- </bean>
- <bean id="userImpl5Dao" class="com.wys.dao.impl.UserDao5Impl">
- <property name="jdbcTemplate" ref="jdbcTemplate" />
- </bean>
其实方法还有很多种,关键是看你是需要继承还是组合,需要注入的对象是什么!
[转] SpringJdbc的几种不同的用法的更多相关文章
- SharedPreferences 的另一种场景的用法
SharedPreferences 的另一种场景的用法 昨天,下班在家想做什么来着,然后想用SharedPreferences存点数据,但是不知道咋地突然想到,SharedPreferences是应用 ...
- [转]jQuery的each方法的几种常用的用法
下面提一下jQuery的each方法的几种常用的用法 复制代码 代码如下: var arr = [ "one", "two", "three&quo ...
- 避免常见的6种HTML5错误用法
一.不要使用section作为div的替代品 人们在标签使用中最常见到的错误之一就是随意将HTML5的<section>等价于<div>——具体地说,就是直接用作替代品(用于样 ...
- Java 枚举(enum) 详解7种常见的用法
Java 枚举(enum) 详解7种常见的用法 来源 https://blog.csdn.net/qq_27093465/article/details/52180865 JDK1.5引入了新的类型— ...
- 一直被用错的6种SQL 错误用法
一直被用错的6种SQL 错误用法 1.LIMIT 语句 2.隐式转换 3.关联更新.删除 4.EXISTS语句 5.条件下推 6.提前缩小范围 sql语句的执行顺序: FROM ON JOIN WHE ...
- MySQL常见的8种SQL错误用法
MySQL常见的8种SQL错误用法 前言 MySQL在2016年仍然保持强劲的数据库流行度增长趋势.越来越多的客户将自己的应用建立在MySQL数据库之上,甚至是从Oracle迁移到MySQL上来.但也 ...
- C++中三种new的用法
转载自:http://news.ccidnet.com/art/32855/20100713/2114025_1.html 作者: mt 1 new operator,也叫new表达式:new表达式比 ...
- asp.net中的<%%>的几种形式的用法
转自:http://blog.csdn.net/wang379275614/article/details/9625911 在asp.net中经常出现包含这种形式<%%>的html代码,总 ...
- PLSQL 几种游标的用法
分类: Oracle 1. PL/SQL里的游标可以分为显式和隐式两种,而隐式有分为select into隐式游标和for .. in 隐式游标两种.所以,我们可以认为,有3种游标用法: A. 显式游 ...
随机推荐
- laravel使用多个数据库连接
1.配置.env文件 DB_CONNECTION=mysql DB_HOST=127.0.0.1 DB_PORT=3306 DB_DATABASE=database_name DB_USERNAME= ...
- 打不开BT,一直重复的关闭开启。
/bt-btif (25335): ...preload_wait_timeout (retried:0/max-retry:1)...D/bt_userial(25335): RX terminat ...
- SQL添加表字段以及SQL查询表,表的所有字段名
通用式: alter table [表名] add [字段名] 字段属性 default 缺省值 default 是可选参数 增加字段: alter table [表名] add 字段名 smalli ...
- Java学习笔记之接口和抽象类
接口(interface)1.interface创建一个接口,implements实现接口 interface jiekou{} class lie implements jiekou{}2.接口可以 ...
- Drupal7的theme函数执行顺序
theme('name') 执行顺序: 1.当前主题_name(),这个函数一般在主题的template.php文件中 2.所在模块_name() 3.theme_name() 4.name.tpl. ...
- 转 当当网资深DBA:DB运维四大现代化的实现
位好,今天我的主题是 <DB运维的四个现代化> ,看标题就能明白,是关于DBA自动化运维平台的事情.http://dbaplus.cn/news-21-855-1.html 主要是分享下我 ...
- java跳过构造方法新建对象
Java有四种创建对象的方法: (1) 用new语句创建对象,这是最常见的创建对象的方法. (2) 运用反射手段,调用java.lang.Class或者java.lang.reflect.Constr ...
- OpenGL—Android 开机动画源码分析一
.1 Android开机动画实现方式目前实现Android开机动画的方式主要是逐帧动画和OpenGL动画. ?逐帧动画 逐帧动画是一种常见的动画形式(Frame By Frame),其原理是在“连续的 ...
- POJ 2318 TOYS 叉积
题目大意:给出一个长方形盒子的左上点,右下点坐标.给出n个隔板的坐标,和m个玩具的坐标,求每个区间内有多少个玩具. 题目思路:利用叉积判断玩具在隔板的左方或右方,并用二分优化查找过程. #includ ...
- DZY Loves Partition
问题描述 DZY喜欢拆分数字.他想知道能否把nn拆成恰好kk个不重复的正整数之和. 思考了一会儿之后他发现这个题太简单,于是他想要最大化这kk个正整数的乘积.你能帮帮他吗? 由于答案可能很大,请模10 ...