Spring JDBC的使用方法详解
作者:幸福的小耗子 发布时间:2021-12-08 14:05:42
标签:sprin,jdbc,使用
1、为什么使用Spring提供的JDBC的封装?
因为Spring提供了完整的模板类以及基类可以简化开发,我们只需写少量的代码即可。
2、实例讲解
第一步:导入依赖mysql-connector spring-jdbc spring-tx spring-core spring-beans spring-context 等等
第二步:数据库的建立,配置xml
第三步:获取jdbcTemplate对象
可以这样获得
private JdbcTemplate jdbcTemplate;
public void setDataSource(DataSource dataSource){
this.jdbcTemplate=new JdbcTemplate(dataSource);
}
<bean id="userDao" class="com.test.jdbc.dao.impl.UserDaoImpl">
<property name="dataSource" ref="dataSource"/>
</bean>
也可以继承JdbcDaoSupport,使用super.getJdbcTemplate()获得
第四步:使用jdbcTemplate对象进行增删改查
增删改使用update(),这个方法的参数,第一个为sql语句,之后为可变参数,传入sql语句中的占位符
查询使用queryForObject()方法的第一个参数为sql中需要的参数,第三个参数为实现RowMapper接口的对象,
用于处理结果集,该方法要求返回单一的对象
query()该方法返回对象集合
public class UserDaoImpl extends JdbcDaoSupport implements IUserDao {
public void save(User user) {
super.getJdbcTemplate().update("insert into user(id,username,password,date,salary) values(null,?,?,?,?)",
user.getUsername(),user.getPassword(),user.getDate(),user.getSalary());
}
public void update(User user) {
super.getJdbcTemplate().update("update user set username=?,password=?,date=?,salary=? where id=?",
user.getUsername(), user.getPassword(), user.getDate(), user.getSalary(), user.getId());
}
public void delete(Integer id) {
super.getJdbcTemplate().update("delete from user where id=?",id);
}
public User findById(Integer id) {
/* List<User> user = super.getJdbcTemplate().query("select * from user where id=?", new Object[]{id},
new RowMapper<User>() {
@Override
public User mapRow(ResultSet resultSet, int i) throws SQLException {
User user = new User();
user.setId(resultSet.getInt("id"));
user.setDate(resultSet.getDate("date"));
user.setUsername(resultSet.getString("username"));
user.setPassword(resultSet.getString("password"));
user.setSalary(resultSet.getBigDecimal("salary"));
return user;
}
//方法的返回值会直接封装到集合中
});
return user.size()>0?user.get(0):null;*/
User user = super.getJdbcTemplate().queryForObject("select * from user where id=?", new Object[]{id},
new RowMapper<User>() {
@Override
public User mapRow(ResultSet resultSet, int i) throws SQLException {
User user = new User();
user.setId(resultSet.getInt("id"));
user.setDate(resultSet.getDate("date"));
user.setUsername(resultSet.getString("username"));
user.setPassword(resultSet.getString("password"));
user.setSalary(resultSet.getBigDecimal("salary"));
return user;
}
});
return user;
}
public List<User> findAll() {
List<User> users = super.getJdbcTemplate().query("select * from user",
new RowMapper<User>() {
@Override
public User mapRow(ResultSet resultSet, int i) throws SQLException {
User user = new User();
user.setId(resultSet.getInt("id"));
user.setDate(resultSet.getDate("date"));
user.setUsername(resultSet.getString("username"));
user.setPassword(resultSet.getString("password"));
user.setSalary(resultSet.getBigDecimal("salary"));
return user;
}
//方法的返回值会直接封装到集合中
});
return users;
}
}
3、JdbcTemplate是JDBC核心包的中心类
知识点查询地址:
https://docs.spring.io/spring-framework/docs/current/spring-framework-reference/data-access.html#jdbc
来源:https://www.cnblogs.com/xfdhh/p/11488317.html
![](https://www.aspxhome.com/images/zang.png)
![](https://www.aspxhome.com/images/jiucuo.png)
猜你喜欢
- 安装APKpublic class DownLoadApk { public static SharedPreferences shared
- 前言大家都知道在Java中,除了8种基本数据类型外,其他的都是引用类型。使用引用类型是为了更好地贯彻面向对象的思想,那为什么还要保留8种基本
- 近日工程中,逐渐感觉到原来复制粘贴代码的笨重,突然想起以前有人和我说起过Git和SVN之类的版本管理工具。由于平时主要是写Java代码,所以
- 如下:public Object invokeMethod(String className, String methodName,Obje
- 这篇文章主要介绍了Spring Boot Logback配置日志过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考
- tcp客户端示例#include <errno.h> #include <sys/socket.h> #includ
- 实践过程😜富文本芝麻粒儿提醒:标签是成对出现的就不要省略,有的不是成对的在修改了后就恢复过来,如下方alpha示例,否则多了很容易出现意外的
- 经过几天的折腾,终于到了学习一个重量级的查询方式上,使用@Query注解,使用注解有两种方式,一种是JPQL的SQL语言方式,一种是原生SQ
- 函数四个方面:函数的定义函数的特点函数的应用函数的重载一、函数的定义及特点1) 什么是函数?函数就是定义在类中的具有特定功能的一段独立小程序
- 有些情况下,在开发一些C#小项目的时候,交付给别人用的时候就是单独EXE文件,但是若涉及什么EXCEL,图片什么的时候,比较麻烦,这时候可以
- 我们在使用editText控件的时候,会遇到这样的一问题,就是我在输入时候,当我选择让文字变粗时,我输入的文字就会变粗,当我去掉选择时,再输
- 我们有时用C#需要实现锁住文件的功能,该如何锁住文件呢?下面小编给大家介绍一下。首先大家需要到码云里面找到如下图所示的文件锁的项目,如下图所
- 一、系统介绍本系统实现的以下功能管理员功能:登录系统、病人信息的增删改查、就医档案的录入、医生信息的增删改查、科室信息的增删改查、收费统计功
- 本文实例讲述了C#实现为一张大尺寸图片创建缩略图的方法。分享给大家供大家参考。具体实现方法如下:public static Bitmap C
- 预处理指令这些指令/命令不会转换为可执行代码,但会影响编译过程的各个方面;列如,可以让编译器不编译某一部分代码等。C#中主要的预处理指令#d
- 题目给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。示例 1:输入: 123输出: 321 示例
- resultMap标签继承、复用、嵌套记录演示 Mybatis 中 resultMap 标签继承、复用(包括跨文件)以及多层嵌套的使用方法,
- 关于Unity的换装,网上有几篇文章,我之前也简单的描述过实现。不过那个时候只是粗略的试验了下。今天好好梳理了下代码。先上代码(自己的游戏项
- 在EditText输入数字的时候,通常我们需要限制小数点前后位数。比如金额输入一般我们需要限制小数点后面最多2位。我们可以通过 TextWa
- ListView是开发中最常用的控件了,但是总是会写重复的代码,浪费时间又没有意义。最近参考一些资料,发现一个万能ListView适配器,代