【Spring-Jdbc】简单的增删改查

Spring-Jdbc】简单的增删改查

1 简介

Spring框架对于数据库的支持是有的,在springJdbc中,为我们提供了一个Jdbc Template模版类,其中为我们大量的封装数据库操作方法。

2 使用

2.1 导入依赖

<dependencies>
  <!--Spring上下文-->
  <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-context</artifactId>
    <version>5.2.12.RELEASE</version>
  </dependency>
  
  <!--Spring Jdbc-->
  <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-jdbc</artifactId>
    <version>5.2.12.RELEASE</version>
  </dependency>
  
  <!--
		Mysql
		这里使用的是spring jdbc内置的数据源,也可以是使用其他的数据源连接池:c3p0等
	-->
  <dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.23</version>
  </dependency>
</dependencies>

2.2 配置数据源

这里的数据源配置使用的是Spring内置的DriverManagerDataSource来配置

<!--配置数据源-->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
  <!--driverClass-->
  <property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/>
  <!--url-->
  <property name="url" value="jdbc:mysql://localhost:3306/spring_jdbc?useSSl=false&amp;serveTimezone=GMT+8&amp;characterEncoding=utf8&amp;useUnicode=true"/>
  <!--username-->
  <property name="username" value="root"/>
  <!--password-->
  <property name="password" value="19981104"/>
</bean>

这里的数据源中的配置信息,也可以通过properties文件来读取

Properties:

driverClassName = com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/spring_jdbc?useSSl=false&serveTimezone=GMT+8&characterEncoding=utf8&useUnicode=true"/>
username=root"
password=19981104"

XML:

读取properties

<!--读取properties-->
<context:property-placeholder location="classpath:jdbc.properties"/>

配置数据源

<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
  <property name="driverClassName" value="${driverClassName}"/>
  <property name="url" value="${url}"/>
  <property name="username" value="${username}"/>
  <property name="password" value="${password}"/>
</bean>

2.3 配置jdbcTemplate

在配置文件中声明bean

<!--配置jdbc模版-->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
  <!--注入数据源-->
  <property name="dataSource" ref="dataSource"/>
</bean>

在使用jdbcTemplate的类中引入,因为只有一个bean,这里就是用spring的按照类型自动装配

// 声明组件
@Repository
public class UserDaoImpl implements UserDao {
    /**
     * 自动注入模版依赖
     */
    @Autowired
    private JdbcTemplate jdbc;
  ...
}

2.4 查询

使用jdbcTemplate进行查询数据库

其中使用到了一个映射类,我们可以自己去实现RowMapper接口,可以自己自定义去管理映射,这里使用Spring为我们提供好的管理映射类BeanPropertyRowMapper,其中泛型和参数就是我们需要返回的实体类。

查询单个对象:

/**
 * 通过id查询用户
 *
 * @param id 用户id
 * @return 用户
 */
@Override
public User queryUserById(int id) {
  // 编写sql语句
  String sql = "SELECT * FROM student WHERE id=?";
  // 使用模版执行sql语句,并返回对应的实体类
  return jdbc.queryForObject(sql, new BeanPropertyRowMapper<User>(User.class), id);
}

模糊查询列表query:

/**
 * 通过名字模糊查询query
 *
 * @param name 名字
 * @return 用户集合
 */
@Override
public List<User> fuzzyQueryUserByName(String name) {
  // 编写sql语句
  String sql = "SELECT * FROM student WHERE `name` LIKE ?";
  // 提交查询,这里使用query来进行查询,返回一个集合
  return jdbc.query(sql, new BeanPropertyRowMapper<User>(User.class), new String("%" + name + "%"));
}

模糊查询列表queryForList:

这种方式的话不需要指定实体类的对象,因为返回来的集合并不是帮我们映射好的实体类,而是数据库中的字段和值的k-v,还是需要我们自己去映射到实体类

/**
 * 通过名字模糊查询queryForList
 *
 * @param name 名字
 * @return 用户集合
 */
@Override
public List<User> fuzzyQueryUserByName(String name) {
  // 编写sql
  String sql = "SELECT * FROM student WHERE `name` LIKE ?";
  // 使用queryForList返回一个list集合,泛型为map集合
  List<Map<String, Object>> maps = jdbcTemplate.queryForList(sql, new Object[]{"%" + name + "%"});
  // 遍历这个List集合
  for (Map<String, Object> map : maps) {
    // 遍历这个map集合
    Set<Map.Entry<String, Object>> entries = map.entrySet();
    for (Map.Entry<String, Object> entry : entries) {
      // map集合的key就是数据库的字段,value就是这个字段对应的值
      System.out.println(entry.getKey());
      System.out.println(entry.getValue());
    }
  }
}

2.5 新增

spring 的jdbc模版还是和直接操作的jdbc一样,新增,修改,删除都是使用update

/**
 * 新增用户
 *
 * @param user 新用户
 * @return 新增结果
 */
@Override
public int addUser(User user) {
  // 编写sql语句
  String sql = "INSERT INTO student VALUES(?,?,?,?)";
  // 提交新增,返回操作结果数
  return jdbc.update(sql, new Object[]{user.getId(), user.getName(), user.getAddress(), user.getMyAge()});
}

2.6 修改

这里和新增的方法一样,我们只需要去修改下自己的sql

/**
 * 更新用户
 *
 * @param user 更新的用户
 * @return 更新结果
 */
@Override
public int updateUser(User user) {
  // 编写sql
  String sql = "UPDATE student SET `name`=?,address=?,my_age=? WHERE id=?";
  // 提交操作,返回操作结果数
  return jdbc.update(sql, new Object[]{user.getName(), user.getAddress(), user.getMyAge(), user.getId()});
}

2.7 删除

/**
 * 通过id删除用户
 *
 * @param id 用户id
 * @return 删除结果
 */
@Override
public int removeUserById(int id) {
  // 编写sql
  String sql = "DELETE FROM student WHERE id=?";
  // 返回操作数结果,这里也可以直接添加参数
  return jdbc.update(sql, id);
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【2021年,将Spring全家桶系列课程进行Review,修复顺序等错误。进入2022年,将Spring的课程进行整理,整理为案例精讲的系列课程,并新增高级的Spring Security等内容,通过手把手一步步教你从零开始学会应用Spring,课件将逐步进行上传,敬请期待】 本课程是Spring案例精讲课程的第五部分Spring Data,Spring案例精讲课程以真实场景、项目实战为导向,循序渐进,深入浅出的讲解Java网络编程,助力您在技术工作中更进一步。 本课程聚焦Spring Data的核心知识点:Spring Data Repository、Spring Data JPA(增删改查案例、实体自动生成数据库表、增加新的Repository方法、分页、排序、@NamedQuery、@Query及其分页和排序及参数设置、@NamedEntityGragh实现多对多映射、及QueryHints等)、Spring Data JDBC增删改查案例、@Query等)的案例介绍, 快速掌握Spring Data的核心知识,快速上手,为学习及工作做好充足的准备。 由于本课程聚焦于案例,即直接上手操作,对于Spring的原理等不会做过多介绍,希望了解原理等内容的需要通过其他视频或者书籍去了解,建议按照该案例课程一步步做下来,之后再去进一步回顾原理,这样能够促进大家对原理有更好的理解。 【通过Spring全家桶,我们保证你能收获到以下几点】 1、掌握Spring全家桶主要部分的开发、实现2、可以使用Spring MVC、Spring Boot、Spring Cloud及Spring Data进行大部分的Spring开发3、初步了解使用微服务、了解使用Spring进行微服务的设计实现4、奠定扎实的Spring技术,具备了一定的独立开发的能力  【实力讲师】 毕业于清华大学软件学院软件工程专业,曾在Accenture、IBM等知名外企任管理及架构职位,近15年的JavaEE经验,近8年的Spring经验,一直致力于架构、设计、开发及管理工作,在电商、零售、制造业等有丰富的项目实施经验  【本课程适用人群】如果你是一定不要错过!  适合于有JavaEE基础的,如:JSP、JSTL、Java基础等的学习者没有基础的学习者跟着课程可以学习,但是需要补充相关基础知识后,才能很好的参与到相关的工作中。 【Spring全家桶课程共包含如下几门】5. 进阶篇:SpringData 

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值