热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

基于ssm的增删改查功能

1.在application.properties里面添加连接数据库的信息。spring.datasource.urljdbc:mysql:localhost:3306empdb?

1.在application.properties里面添加连接数据库的信息。

spring.datasource.url=jdbc:mysql://localhost:3306/empdb?characterEncoding=utf8&serverTimezone=Asia/Shanghai&useSSL=false
spring.datasource.username=root
spring.datasource.password= //写自己的数据库密码

2.创建Emp实体类,因为Mybatis框架是通过实体类和表之间的对应关系生成JDBC代码的,所以必须要有实体类。

public class Emp {private Integer id;private String name;private Integer sal;private String job;@Overridepublic String toString() {return "Emp{" +"id=" + id +", name='" + name + '\'' +", sal=" + sal +", job='" + job + '\'' +'}';}public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public Integer getSal() {return sal;}public void setSal(Integer sal) {this.sal = sal;}public String getJob() {return job;}public void setJob(String job) {this.job = job;}
}

3.创建EmpMapper,Mybatis框架需要从EmpMapper接口中得到需要执行的SQL语句,以及对象和表之间的映射关系。在Mapper中添加@Mapper注解。


  • @Insert注解修饰一个insert方法。
  • @Select是查询的注解,返回值为集合,Mybatis框架生成的jdbc代码会将查询到的数据封装到Emp对象中,然后把Emp对象装进list集合,通过方法返回。

import entity.Emp;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;/*
* @Mapper
* 将接口交给Spring管理,不用再写pom.xml文件,为此接口生成一个实现类让其他类引用。
* */
@Mapper
public interface EmpMapper {@Insert("insert into myemp values(name,#{name},#{sal},#{job})")void insert(Emp emp);@Select("select * from myemp")List select();//查询带条件而且查询结果是一个对象时@Select("select * from myemp where id=#{id}")Emp selectById(int id);//查询到结果有多条数据,用一个对象作为返回会报错,应该用集合@Select("select * from myemp where name=#{name}")List selectByName(String name);//方法返回值为int时 返回的是生效的行数@Update("update myemp set name=#{name},sal=#{sal},job=#{job} where id=#{id}")int update(Emp emp);//删除注解@Delete("delete from myemp where id=#{id}")void deleteById(int id);
}

4.单元测试,在test目录下。

import cn.tedu.boot31_1.entity.Emp;
import cn.tedu.boot31_1.mapper.EmpMapper;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;@SpringBootTest
class Boot311ApplicationTests {//把Mapper装配起来@Autowired(required = false)EmpMapper mapper;@Testvoid contextLoads() {Emp e = new Emp();e.setName("曹操");e.setSal(10000);e.setJob("司空");mapper.insert(e);}@Testvoid select(){List list = mapper.select();for (Emp e:list){System.out.println(e.getName()+":"+e.getSal()+":"+e.getJob());}}@Testvoid select02(){Emp e = mapper.selectById(3);System.out.println(e);}@Testvoid select03() {List list = mapper.selectByName("诸葛亮");System.out.println(list);}@Testvoid update(){Emp e = new Emp();e.setId(4);e.setName("卧龙");e.setSal(5000);e.setJob("程序员");int row = mapper.update(e);System.out.println("行数="+row);}@Testvoid delete(){mapper.deleteById(4);}
}

添加成功 

查询成功

查询id为3的

 查询两个诸葛亮

 修改id为4的诸葛亮信息并显示修改的条数

 

删除四号员工 


推荐阅读
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 本文详细探讨了JDBC(Java数据库连接)的内部机制,重点分析其作为服务提供者接口(SPI)框架的应用。通过类图和代码示例,展示了JDBC如何注册驱动程序、建立数据库连接以及执行SQL查询的过程。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • Windows服务与数据库交互问题解析
    本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
  • 本文详细介绍了如何通过多种编程语言(如PHP、JSP)实现网站与MySQL数据库的连接,包括创建数据库、表的基本操作,以及数据的读取和写入方法。 ... [详细]
  • 本文介绍如何通过创建替代插入触发器,使对视图的插入操作能够正确更新相关的基本表。涉及的表包括:飞机(Aircraft)、员工(Employee)和认证(Certification)。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 实体映射最强工具类:MapStruct真香 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 本文作者分享了在阿里巴巴获得实习offer的经历,包括五轮面试的详细内容和经验总结。其中四轮为技术面试,一轮为HR面试,涵盖了大量的Java技术和项目实践经验。 ... [详细]
  • 本文探讨了 Spring Boot 应用程序在不同配置下支持的最大并发连接数,重点分析了内置服务器(如 Tomcat、Jetty 和 Undertow)的默认设置及其对性能的影响。 ... [详细]
  • 深入解析 Spring Security 用户认证机制
    本文将详细介绍 Spring Security 中用户登录认证的核心流程,重点分析 AbstractAuthenticationProcessingFilter 和 AuthenticationManager 的工作原理。通过理解这些组件的实现,读者可以更好地掌握 Spring Security 的认证机制。 ... [详细]
  • 本文探讨了如何在日常工作中通过优化效率和深入研究核心技术,将技术和知识转化为实际收益。文章结合个人经验,分享了提高工作效率、掌握高价值技能以及选择合适工作环境的方法,帮助读者更好地实现技术变现。 ... [详细]
  • 本文详细介绍了 org.apache.commons.io.IOCase 类中的 checkCompareTo() 方法,通过多个代码示例展示其在不同场景下的使用方法。 ... [详细]
author-avatar
采臣--小青在这_203
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有