Springboot整合jdbc_template

news2025/1/8 5:54:16

1.构建Springboot项目

利用springboot整合jdbctemplate,并不需要导入其他的依赖,具体的项目结构图如图
在这里插入图片描述

2.写domain层

数据库映射的实体类

package com.jkk.springboot_jdbc_template.domain;

/**
 * @author jkk
 */

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.ToString;

import java.io.Serializable;

/**
 * Users类将数据库中的users表映射在一起
 * @author jkk
 * @see java.io.Serializable
 */
@Data
@AllArgsConstructor
@NoArgsConstructor
@ToString
public class Users implements Serializable {
    private String username;
    private String password;
    private String idNumber;
    private String phoneNumber;
    private String gender;
    private String dataStatus;
    private static final long serialVersionUID = 1L;
}

3.mapper层

是对数据库的操作,可以直接注入
在这里插入图片描述

package com.jkk.springboot_jdbc_template.mapper;

import com.jkk.springboot_jdbc_template.domain.Users;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Repository;

import java.util.List;

/**
 * 这一层是数据库访问层.
 * <p>主要是对数据库的增删查改</p>
 * @author jkk
 */
@Repository
public class UsersMapper {
    @Autowired
    JdbcTemplate jdbcTemplate;

    public int addUser(Users users){
        return jdbcTemplate.update("insert into users(username,password,id_number,phone_number,gender,data_status) values (?,?,?,?,?,?)",
                users.getUsername(),users.getPassword(),users.getIdNumber(),users.getPhoneNumber(),users.getGender(),users.getDataStatus());
    }

    public int updateUser(Users users){
        return jdbcTemplate.update("update users set password=?,id_number=?,phone_number=?,gender=?,data_status=? where username=?",
                users.getPassword(),users.getIdNumber(),users.getPhoneNumber(),users.getGender(),users.getDataStatus(),users.getUsername());
    }

    public int deleteByUserName(String userName){
        return jdbcTemplate.update("delete from users where username = ?",userName);
    }

    public Users getByUserName(String userName){
        return jdbcTemplate.queryForObject("select * from users where username = ?",new BeanPropertyRowMapper<>(Users.class),userName);
    }

    public List<Users> getAllUser(){
        return jdbcTemplate.query("select * from users",new BeanPropertyRowMapper<>(Users.class));
    }
}

4.service层

package com.jkk.springboot_jdbc_template.service;

import com.jkk.springboot_jdbc_template.domain.Users;
import org.springframework.stereotype.Service;

import java.util.List;

/**
 * @author jkk
 */
public interface UserService {
    /**
     * 添加用户信息
     * @param users
     * @return
     */
    public int addUser(Users users);

    /**
     * 修改用户信息
     * @param users
     * @return
     */
    public int updateUser(Users users);

    /**
     * 删除用户信息
     * @param userName
     * @return
     */
    public int deleteByUserName(String userName);

    /**
     * 查找单个信息
     * @param userName
     * @return
     */
    public Users getByUserName(String userName);

    /**
     * 查询所有信息
     * @return
     */
    public List<Users> getAllUser();
}

package com.jkk.springboot_jdbc_template.service.impl;

import com.jkk.springboot_jdbc_template.domain.Users;
import com.jkk.springboot_jdbc_template.mapper.UsersMapper;
import com.jkk.springboot_jdbc_template.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.List;

/**
 *具体的业务逻辑层.
 * @see com.jkk.springboot_jdbc_template.service.UserService
 * @author jkk
 */
@Service
public class UserServiceImpl implements UserService {
    @Autowired
    private UsersMapper usersMapper;
    @Override
    public int addUser(Users users) {
        return usersMapper.addUser(users);
    }

    @Override
    public int updateUser(Users users) {
        return usersMapper.updateUser(users);
    }

    @Override
    public int deleteByUserName(String userName) {
        return usersMapper.deleteByUserName(userName);
    }

    @Override
    public Users getByUserName(String userName) {
        return usersMapper.getByUserName(userName);
    }

    @Override
    public List<Users> getAllUser() {
        return usersMapper.getAllUser();
    }
}

5.controller层

package com.jkk.springboot_jdbc_template.controller;

import com.jkk.springboot_jdbc_template.domain.Users;
import com.jkk.springboot_jdbc_template.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;

/**
 * @author jkk
 */
@RestController
public class UsersController {
    @Autowired
    private UserService userService;

    @GetMapping("/user")
    public String userTest(){
        Users users = new Users();
        users.setUsername("test4");
        users.setPassword("test4");
        users.setIdNumber("444");
        users.setPhoneNumber("444");
        users.setGender("男");
        users.setDataStatus("0");
        int add = userService.addUser(users);
        int delete = userService.deleteByUserName("test3");
        users.setPhoneNumber("555");
        int update = userService.updateUser(users);
        Users test4 = userService.getByUserName("test4");
        System.out.println(test4);
        List<Users> allUser = userService.getAllUser();
        System.out.println(allUser);
//        return "插入了"+add+"行,删除了"+delete+"行,更新了"+update+"行";
        return test4.toString();
    }
}


在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/713175.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

04 - C++学习笔记: 循环语句和跳转语句

在C编程中&#xff0c;循环语句和跳转语句是非常重要的控制结构。循环语句允许重复执行一段代码&#xff0c;而跳转语句允许在程序执行过程中改变执行的流程。本篇笔记将介绍C中常用的循环语句和跳转语句&#xff0c;并通过例子进行说明。 &#x1f501;循环类型 C 编程语言提…

查询子节点 postgresql

数据库为postgresql WITH RECURSIVE cte AS (SELECTn. ID,n. com_name,n."parentId" AS pidFROMcompany AS nWHEREn. ID = 2UNION ALLSELECTr. ID,r. com_name,cte. ID AS pidFROMcteJOIN company AS r ON r.

轻松实现邮箱验证码功能!快来体验Spring Boot的神奇力量!

邮件验证是现代互联网服务中常用的安全功能&#xff0c;本文介绍如何利用Spring Boot框架快速搭建一个高效易用的邮箱验证码功能。从配置邮箱>发送服务&#xff0c;到编写验证逻辑&#xff0c;无痛实现邮箱验证码功能轻而易举。快来掌握这个技能&#xff0c;加强您的应用安全…

论文解读 | CVPR 2020:PV-RCNN:用于三维物体检测的点体素特征集提取

原创 | 文 BFT机器人 论文《PV-RCNN: Point-Voxel Feature Set Abstraction for 3D Object Detection》是一篇关于三维物体检测的论文。该论文提出了一种名为PV-RCNN的方法&#xff0c;用于从点云数据中进行三维物体检测&#xff0c;并在各种应用中取得了优秀的性能。 论文的主…

数据库第一章

一。数据库 1.概述 数据库database用来存储数据和管理数据的仓库 分类&#xff1a;关系型MySQL/非关系型Redis 关系型数据库&#xff08;二维表格模型&#xff09;&#xff1a;Oracle,MySQL,SQLServer,Access 非关系型数据库&#xff1a;MongoDB&#xff0c;Redis&#xf…

linux 文件锁flock与fcntl bytes级别精细控制不再是困难

​专栏内容&#xff1a; postgresql内核源码分析 手写数据库toadb 并发编程 个人主页&#xff1a;我的主页 座右铭&#xff1a;天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物. 文件锁 概述 前面博客介绍了多任务下互斥的方法&#xff0c;如…

Docker容器的数据卷

Docker容器的数据卷 一、数据卷概念 概念&#xff1a;数据卷是宿主机中的一个目录或文件 当容器目录和数据卷目录绑定后&#xff0c;对方的修改会立即同步一个数据卷可以被多个容器同时挂载一个容器也可以挂载多个数据卷 可以解决以下问题 可以解决容器数据的持久化&#xff0…

高效学习法

目标明确&#xff0c;难度适中 全面&#xff1a;宏观概述&#xff0c;微观详尽 明确&#xff1a;目标要明确&#xff0c;否则陷入选择漩涡&#xff0c;导致大脑内耗。李白的“行路难&#xff0c;多歧路” 渐进&#xff1a;既要进步&#xff0c;也要逐步…

47 # 实现可读流

上一节讲了 fs.createReadStream 创建一个可读流&#xff0c;那么怎么查看它的源码是怎么实现的&#xff1f; 我们可以采用打断点的方式&#xff1a;我们可以看到先执行了 lazyLoadStreams 如果没有 ReadStream 就会 require 内部的 internal/fs/streams 模块 通过 internal/f…

免费开源 | 基于SpringBoot+Vue的物流管理系统

1-介绍 基于SpringBootvuemybatis-plus的简单的物流管理系统DEMO,前后端分离&#xff0c;可用于扩展基础&#xff0c;可用于简单课设&#xff0c;可用于基础学习 2-技术架构 SpringBootvuemybatis-plusmysql 8.0 3-使用说明 安装数据库demo/sql/wuliu.sql运行后端demo 1-…

QT调用glog日志流程

glog日志库是Google开源的轻量级的日志库&#xff0c;平时在开发过程中经常要使用到日志&#xff0c;本篇记录Qt项目使用glog日志库的记录。 1.首先下载cmake&#xff0c;Download | CMake 安装设置环境变量&#xff0c;检查安装情况 2.下载glog源码 git clone https://git…

指数分布的概率密度推导

指数分布的概率密度&#xff0c;一直理解的不够深入&#xff0c;一直都不明白为什么是这么奇怪的形式&#xff0c;指数位置的分母为什么有个-theta&#xff0c;也一直不太明白该分布的特点&#xff0c;直到看到如下篇博文&#xff1a; 指数分布概率密度推导1 指数分布概率密度…

PyCharm安装配置PyQt5/QtDesigner/PyUic的超详细教程

目录 1.介绍 2.安装与配置 1.下载安装PyQt5 2.QtDesignerPyUic的安装配置 1.下载安装 2.打开designer.exe所在位置 3.配置PyCharm QtDesigner 4.验证安装是否成功 5.PyCharmPyUic快捷菜单工具配置:便于将Qt的UI文件转换成.py文件 6.配置PyQt5 PyRcc:便于将资源文件转码 1…

拒绝裸奔,使用jasypt为SpringBoot配置文件进行加密。

平日使用Github上传代码时&#xff0c;不可避免的会遇到一个问题就是配置文件中的敏感信息的处理&#xff0c;如MySQL的用户名密码&#xff0c;Redis的密码等。而如果一不注意提交到Github后&#xff0c;无异于出门不锁还留把钥匙&#xff0c;后果不堪设想&#xff0c; 近些年开…

随笔-毕业十周年聚会

文章目录 随笔-毕业十周年聚会1. 引子2. 流水账3. 感悟 随笔-毕业十周年聚会 1. 引子 上周三&#xff0c;许久不联系的班长给我发了个微信&#xff0c;问我周六有没有时间&#xff0c;学校和学院组织了毕业十周年校友返校活动&#xff0c;凑着这个机会大家聚一聚。 一时间有…

SpringBoot项目从0到1配置logback日志打印

大家好&#xff01;我是sum墨&#xff0c;一个一线的底层码农&#xff0c;平时喜欢研究和思考一些技术相关的问题并整理成文&#xff0c;限于本人水平&#xff0c;如果文章和代码有表述不当之处&#xff0c;还请不吝赐教。 以下是正文&#xff01; 一、写文背景 我们在写后端…

运输层:UDP和TCP对比

1.运输层&#xff1a;UDP和TCP对比 笔记来源&#xff1a; 湖科大教书匠&#xff1a;UDP和TCP对比 声明&#xff1a;该学习笔记来自湖科大教书匠&#xff0c;笔记仅做学习参考 无连接的UDP、面向连接的TCP UDP支持单播&#xff08;一对一&#xff09;、多播&#xff08;一对多…

2023上半年软考系统分析师科目一整理-18

2023上半年软考系统分析师科目一整理-18 使用 Cache 改善系统性能的依据是程序的局部性原理。程序中大部分指令是&#xff08;&#xff09;的。设某计算机主存的读&#xff0f;写时间为 100ns&#xff0c;有一个指令和数据合一的 Cache&#xff0c;已知该 Cache的读&#xff0f…

飞控学习笔记-姿态角的描述(1)

方向余弦矩阵 c12为方向余弦矩阵 四元数 欧拉角 四元数-方向余弦-欧拉角的关系

【微服务】SpringBoot服务瘦身部署

(内容学习于up主"编程不良人") SpringBoot瘦身实战 什么是jar瘦身 SpringBoot 应用瘦身顾名思议&#xff1a;就是将 SpringBoot 应用打包的 jar 利用合理的方式、方法减小体积。 为什么瘦身 SpringBoot虽然很方便就能搭建起来一个服务&#xff0c;带来的问题就是…