草庐IT

JDBCTemplate- SpringBoot(14)

liwenruo 2023-04-15 原文

1.认识 JDBCTemplate

1.了解 JDBC

  学习使用 JDBCTempIate 之前,我们先来了解一下 JDBC( Java DataBase Connectivity )。 它是Java用于连接数据库的规范,也就是用于执行数据库SQL语句的Java API。从JDBC的名称上看,它似乎没有指定某种数据库。可以猜想它可以为多种数据库提供统一访问的接口,这更符合程序设计的模式。实际上,它由一组用Java语言编写的类和接口组成,为大部分关系型数据库提供访问接口。

  JDBC需要每次进行数据库连接,然后处理SQL语句、传值、关闭数据库。如果都由开发人员编写代码,则很容易岀错,可能会出现使用完成之后,数据库连接忘记关闭的情况。这容易导致连接被占用而降低性能,为了减少这种可能的错误,减少开发人员的工作量,JDBCtemplate就被设计岀来了

  2.了解 JDBCTemplate

  JDBCTemplate=JDBC+Template的组合,是对JDBC的封装。它更便于程序实现,替我们完成所有的JDBC底层工作。因此,对于数据库的操作,再不需要每次都进行连接、打开、关闭了。 现在通过JDBCtemplate不需要进行全局修改,就可以轻松地应对开发人员常常要面对的增加、 删除、修改和查询操作。

  JDBC和JDBCtemplate就像是仓库管理员,负责从仓库(数据库)中存取物品。而后者不需 要"每次进入都开门,取完关门”,因为有电动门自动控制。下面通过具体使用JDBCTemplate的实例来理解它。

  实例: 用JDBCTemplate实现数据的增加、删除、修改和查询

  (1)配置基础依赖

  使用JDBCTemplate,则需要添加其Starter依赖。因为要操作数据库,所以也需要配置数据库(以MySQL为例)的连接依赖,见以下代码:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <scope>runtime</scope>
</dependency>

  添加完依赖后,还需要配置数据库的连接信息。这样JDBCTemplate才能正常连接到数据库。 在application.yml配置文件中配置数据库的地址和用户信息,见以下代码:“配置IP地址、编码、时区和SSL”

spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/springboot?useUnicode=true&characterEncoding=utf-8&serverTimezone=UTC&useSSL=true
    username: root
    password: 123456

  (2)新建实体类

  新建一个测试实体类User,实现RowMapper类,重写mapRow方法,以便实体字段和数据表字段映射(对应),映射是指把Java中设置的实体字段和MySQL数据库的字段对应起来,因 为实体的id可以对应数据库字段的u_id,也可以对应id、name等。如果不重写,则程序不知道如 何对应。具体代码如下:

package com.itheima.domain;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.springframework.jdbc.core.RowMapper;
import java.sql.ResultSet;
import java.sql.SQLException;
@Data
@AllArgsConstructor
@NoArgsConstructor
public class User implements RowMapper<User> {
    private long id;
    private String name;
    private int age;
    @Override
    public User mapRow(ResultSet rs, int rowNum) throws SQLException {
        User user = new User();
        user.setId(rs.getLong("id"));
        user.setName(rs.getString("name"));
        user.setAge(rs.getInt("age"));
        return user;
    }
}

  (3)操作数据

  JDBCTemplate提供了以下操作数据的3个方法。

  • execute:表示“执行”,用于直接执行SQL语句
  • update:表示“更新",包括新增、修改、删除操作。
  • query;表示查询。

  下面使用这3个方法来实现数据的增加、删除、修改和查询功能。

  1.创建数据表

  在使用JDBCTemplate之前,需要在控制器中注入JDBCTemplate,然后就可以通过 "execute"方法执行SQL操作了,见以下代码:

package com.itheima;

import com.itheima.domain.User;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.test.context.junit4.SpringRunner;
import java.util.List;

@SpringBootTest
@RunWith(SpringRunner.class)
public class UserControllerTest {
    @Autowired
    private JdbcTemplate jdbcTemplate;

    @Test
    public void createUserTable() throws Exception {
        String sql = "create table `user` (\n" +
                "`id` int(10) not null auto_increment,\n" +
                "`name` varchar(100) default null,\n" +
                "`age` int(10) default null,\n" +
                "primary key (`id`)\n" +
                ")engine=InnoDB auto_increment=1 default charset=utf8;\n" +
                "\n";
        jdbcTemplate.execute(sql);
    }

}

  2.添加数据。

  添加数据可以通过“update”方法来执行,见以下代码:

@Test
public void saveUserTest() throws Exception{
    String sql = "insert into user (name,age) values('buretuzi','12')";
    int rows = jdbcTemplate.update(sql);
    System.out.println(rows);
}

  3.查询数据

  以下代码是根据name查询单个记录,执行下面sql字符串里的SQL语句(SELECT * FROM user WHERE USERNAME = ? ),这里需要通过“query”方法来执行。

@Test
public void getUserByName() throws Exception {
    String name = "buretuzi";
    String sql = "select * from user where name = ?";
    List<User> users = jdbcTemplate.query(sql,new User(),new Object[]{name});
    for (User user : users) {
    	System.out.println(user);
    }
}

  4.查询所有记录

  查询所有记录和查询单个记录一样,也是执行“query”方法。区别是,SQL语句使用了查询通配符见以下代码:

@Test
    public void list() throws Exception {
    String sql = "select * from user";
    List<User> users = jdbcTemplate.query(sql,new BeanPropertyRowMapper(User.class));
    for (User user : users) {
    	System.out.println(user);
    }
}

5.修改数据。

  要进行数据的修改,可以使用“update”方法来实现,见以下代码:

@Test
public void updateUserPassword() throws Exception {
    Integer id = 1;
    String password = "12331313";
    String sql = "update user set name = ? where id = ?";
    int rows = jdbcTemplate.update(sql,password,id);
    System.out.println(rows);
}

  6.删除数据。

  这里删除数据并不用DELETE方法,而是通过“update”方法来执行SQL语句中的“DELETE” 方法。

@Test
public void deleteUserById() throws Exception {
    String sql = "delete from user where id = ?";
    int rows = jdbcTemplate.update(sql,1);
    System.out.println(rows);
}

  至此,已经实现了简单的增加、删除、修改和查询功能。如果读者对关系型数据库的SQL语句不陌生,那么实现起来会非常简单。因为JDBCTemplate实现起来比ORM烦琐,所以大部分开发人员使用的是ORM (JPA和MyBatis)。但是JDBCTemplate依然有市场,因为学习成本低, 会一些SQL语句就能上手使用,操作虽然麻烦,但很容易学会。

 

有关JDBCTemplate- SpringBoot(14)的更多相关文章

  1. ruby-on-rails - 无法安装 mysql2 0.3.14 gem - 2

    我看到其他人也遇到过类似的问题,但没有一个解决方案对我有用。0.3.14gem与其他gem文件一起存在。我已经完全按照此处指示完成了所有操作:https://github.com/brianmario/mysql2.我仍然得到以下信息。我不知道为什么安装程序指示它找不到include目录,因为我已经检查过它存在。thread.h文件存在,但不在ruby​​目录中。相反,它在这里:C:\RailsInstaller\DevKit\lib\perl5\5.8\msys\CORE\我正在运行Windows7并尝试在Aptana3中构建我的Rails项目。我的Ruby是1.9.3。$gemin

  2. ruby - 在 Ubuntu 14.04 中使用 Curl 安装 RVM 时出错 - 2

    我试图在Ubuntu14.04中使用Curl安装RVM。我运行了以下命令:\curl-sSLhttps://get.rvm.io|bash-sstable出现如下错误:curl:(7)Failedtoconnecttoget.rvm.ioport80:Networkisunreachable非常感谢解决此问题的任何帮助。谢谢 最佳答案 在执行curl之前尝试这个:echoipv4>>~/.curlrc 关于ruby-在Ubuntu14.04中使用Curl安装RVM时出错,我们在Stack

  3. ruby - gem install pg error : couldn't understand kern. osversion `14.0.0' on Yosemite w/Ruby 2.1.5 - 2

    我使用RVM安装Ruby-2.1.5并再次运行bundle。现在pggem不会安装,我得到这个错误:geminstallpg-v'0.17.1'----with-pg-config=/Applications/Postgres.app/Contents/Versions/9.3/bin/pg_configBuildingnativeextensionswith:'--with-pg-config=/Applications/Postgres.app/Contents/Versions/9.3/bin/pg_config'Thiscouldtakeawhile...ERROR:Error

  4. ruby-on-rails - Ubuntu 14.04 Rails 丢失文件 - 2

    安装Rails时,一切都很好,但后来,我写道:rails-v和输出:/home/toshiba/.rvm/rubies/ruby-2.2.1/lib/ruby/site_ruby/2.2.0/rubygems/core_ext/kernel_require.rb:54:in`require':cannotloadsuchfile--rails/cli(LoadError)from/home/toshiba/.rvm/rubies/ruby-2.2.1/lib/ruby/site_ruby/2.2.0/rubygems/core_ext/kernel_require.rb:54:in`r

  5. 使用时 Rubygems 2.0.14 不是线程安全的 bundle 程序安装消息 - RUBYGEMS VERSION : 2. 4.5.1 - 2

    运行bundle安装时,我收到以下消息:Rubygems2.0.14isnotthreadsafe,soyourgemswillbeinstalledoneatatime.UpgradetoRubygems2.1.0orhighertoenableparallelgeminstallation.这很奇怪,因为在我的RubyGems环境中它说我的RubyGems版本是:2.4.5.1(见下文)~/w/Rafftopia❯❯❯gemenvRubyGemsEnvironment:-RUBYGEMSVERSION:2.4.5.1-RUBYVERSION:2.2.5(2016-04-26patc

  6. ruby - 在 Ubuntu 14.04 上使用 RVM 安装 Ruby 2.2.2 时出错 - 2

    这是什么。我首先做了:rvmgetstablervminstallruby-2.2.2没有交易。它向我展示了以下内容:$rvminstallruby-2.2.2Searchingforbinaryrubies,thismighttakesometime.Nobinaryrubiesavailablefor:ubuntu/14.04/i386/ruby-2.2.2.Continuingwithcompilation.Pleaseread'rvmhelpmount'togetmoreinformationonbinaryrubies.Checkingrequirementsforubunt

  7. ruby - 无法在 MacOS 10.14.2 Mojave : Error running '__rvm_make -j4' 上使用 RVM 安装任何 Ruby - 2

    将MacOS升级到10.14.2Mojave后,我无法再使用RVM安装任何Ruby版本。它总是给出这样的错误:$rvminstall2.5.3ruby-2.5.3-#removingsrc/ruby-2.5.3..Searchingforbinaryrubies,thismighttakesometime.Nobinaryrubiesavailablefor:osx/10.14/x86_64/ruby-2.5.3.Continuingwithcompilation.Pleaseread'rvmhelpmount'togetmoreinformationonbinaryrubies.Ch

  8. springboot定时任务 - 2

    如果您希望在Spring中启用定时任务功能,则需要在主类上添加 @EnableScheduling 注解。这样Spring才会扫描 @Scheduled 注解并执行定时任务。在大多数情况下,只需要在主类上添加 @EnableScheduling 注解即可,不需要在Service层或其他类中再次添加。以下是一个示例,演示如何在SpringBoot中启用定时任务功能:@SpringBootApplication@EnableSchedulingpublicclassApplication{publicstaticvoidmain(String[]args){SpringApplication.ru

  9. 基于SpringBoot的线上日志阅读器 - 2

    软件特点部署后能通过浏览器查看线上日志。支持Linux、Windows服务器。采用随机读取的方式,支持大文件的读取。支持实时打印新增的日志(类终端)。支持日志搜索。使用手册基本页面配置路径配置日志所在的目录,配置后按回车键生效,下拉框选择日志名称。选择日志后点击生效,即可加载日志。windows路径E:\java\project\log-view\logslinux路径/usr/local/XX历史模式历史模式下,不会读取新增的日志。针对历史文件可以分页读取,配置分页大小、跳转。历史模式下,支持根据关键词搜索。目前搜索引擎使用的是jdk自带类库,搜索速度相对较低,优点是比较简单。2G日志全文搜

  10. springboot使用validator进行参数校验 - 2

    1.依赖导入org.springframework.bootspring-boot-starter-weborg.springframework.bootspring-boot-starter-validation2.validation常用注解@Null被注释的元素必须为null@NotNull被注释的元素不能为null,可以为空字符串@AssertTrue被注释的元素必须为true@AssertFalse被注释的元素必须为false@Min(value)被注释的元素必须是一个数字,其值必须大于等于指定的最小值@Max(value)被注释的元素必须是一个数字,其值必须小于等于指定的最大值@D

随机推荐