详解如何使用MyBatis实现数据库的CRUD

 更新时间:2024年12月02日 08:32:08   作者:爱上语文  
这篇文章主要为大家详细介绍了如何使用MyBatis实现数据库的CRUD操作,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下

Mybatis中#占位符和$拼接符的区别

“#”占位符

在使用MyBatis操作数据库的时候,可以直接使用如下代码进行删除数据

@Delete("delete from user where id=5")
public Integer deleteById();

这个代码可以成功完成删除user表中id为5的用户,但是其实存在一个问题:硬编码。把这个删除的SQL语句写死了,假如说下一次需要删除id为6的用户就又要重新编写一条SQL了。所以说我们可以使用#占位符:

@Delete("delete from user where id=#{id}")
public Integer deleteById(Integer id);

这样写,需要给deleteById方法传递需要删除的id,并使用#进行占位,在编译时,就会将这条SQL语句编译为一条预编译SQL:delete from user where id=?。然后再用方法中的参数id去对预编译SQL中的?进行参数绑定(将 Java 方法中的参数与 SQL 语句中的占位符建立关联并赋值的动作),从而避免硬编码的问题,并且还可以提高SQL语句的执行效率(预编译SQL提高SQL语句的执行效率)。

“$”拼接符

和#占位符不同,$只是拼接符,是直接将参数值拼接在SQL中,并不能使SQL语句变成预编译SQL,所以说还是存在SQL注入问题和性能低下的问题,所以说用的十分少。但是当表名和字段名需要动态变化的时候,就只能使用$拼接符,如:"select * from ${tablename}"这种动态的表名会使用$拼接符。

Create

create操作是在数据库中新增一条数据,通过MyBatis中的@Insert注解可以便捷的完成数据的新增,当进行数据新增操作时,往往会涉及多个不同类型的属性。从数据组织和管理的角度出发,为了更好地维护数据的完整性和关联性,通常会将这些相关属性封装为一个实体对象。这种实体对象的设计遵循面向对象编程的原则,以业务逻辑中的实际实体为蓝本,例如在用户管理系统中,用户相关的属性(如用户名、密码、姓名、年龄等)会被封装在一个User实体对象中。这个实体对象会作为参数传递给负责新增数据的方法,SQL中的占位符会获取对象中的属性来拼接SQL:

@Insert("insert into user(id, username, password, name, age) " +
        "values (#{id}, #{username}, #{password}, #{name}, #{age})")
public Integer insertUser(User user);

values中的值就是User对象中的属性,是#占位符从User对象中的属性中获取的。(如何获取本文不过多赘述)

测试该方法:

@Test
public void testInsert() {
    User user = new User(null, "zhouyu", "123456", "周瑜", 23);
    Integer rows = userMapper.insertUser(user);
    System.out.println("影响的行数是:" + rows);
}

(因为id字段是主键,并且自增,所以说不需要传递id的参数。)

原数据表:

测试结果:

看到新增的方法成功在数据库表中插入了一条新的数据,代表新增方法成功了。需要说明的是:id是自增的,前面自测的时候创建了很多user,所以说id自增到了10,虽然删除了这些user,但是id也是从10开始自增的,所以说再次添加user,id从10自增,则变成11。

Read

Read操作是查询(读取)数据库中的数据,通过MyBatis中的@Select注解可以便捷的完成数据的查询:

@Select("select * from user where username = #{username} and password = #{password}")
public void selectUser(@Param("username")String username, @Param("password")String password);

此处只需要使用两个字段进行查找,没有必要将属性封装到User对象中,可以直接传递;但是需要非常注意的是此处传递的是参数名,#占位符绑定的也是参数名,但是在编译后方法中的参数名不会保留,只会保留参数的类型,而#占位符参数绑定是在编译后进行的,但是此时有两个参数,#占位符无法进行准确绑定,所以说就会报错。为了解决这个问题,需要在方法的参数之前添加@Param注解来指定该参数的名字,#占位符中也需要和@Param注解中相同的名字(参数名不重要),这样才可以指定参数。但是假如是官方的SpringBoot框架,无需使用@Param注解,只要保证#占位符中的参数和方法的参数名相同即可,也可以完成绑定。

测试方法:

@Test
public void testFind() {
    User user = userMapper.selectUser("liubei", "123456");
    System.out.println(user);
}

发现根据username和password成功查询到了User,说明查找方法成功。

Update

update操作是更新数据库中的数据,通过MyBatis中的@Update注解可以便捷的完成数据的删除:

@Update("update user set username=#{username}, password=#{password}, name=#{name}, age=#{age} where id=#{id}")
public Integer updateUser(User user);

和insert操作类似,需要将要更新的字段封装为对应实体对象的属性,然后通过#占位符获取属性,完成SQL语句的拼接,需要注意的是,在insert操作中,因为id是自增的,所以说不需要传递id属性,但是在update操作中,很多时候都需要根据id属性来找到要更新哪一条数据,所以说大多数时候是需要传递id的,但是也需要根据具体情况而定。

测试方法:

@Test
public void testUpdate() {
    User user = new User(1, "liubei", "123456", "刘备", 25);
    Integer rows = userMapper.updateUser(user);
    System.out.println("影响的行数是:" + rows);
}

测试前数据表:

测试结果:

发现id为1的用户被修改为了刘备,说明该修改方法成功修改。

Delete

delete操作是删除数据库中的数据,通过MyBatis中的@Delete注解可以便捷的完成数据的删除:

@Delete("delete from user where id=#{id}")
public Integer deleteById(Integer id);

在MyBatis中执行所有的DML语句都是有返回值的,是int类型,代表这条语句影响的记录数,通过测试方法来测试下这个删除方法: 原数据表:

测试方法:

@Test
public void testDelete() {
    Integer rows = userMapper.deleteById(5);
    System.out.println("影响的行数是:" + rows);
}

我们看到#占位符确实将SQL变成了一条预编译的SQL,并且这条SQL影响了一条记录。看看数据库中的变化:

id为5的记录确实被删除了,说明该方法测试成功。

以上就是详解如何使用MyBatis实现数据库的CRUD的详细内容,更多关于MyBatis实现数据库CRUD的资料请关注脚本之家其它相关文章!

相关文章

  • springboot设置了server.port但是没有用,还是8080问题

    springboot设置了server.port但是没有用,还是8080问题

    这篇文章主要介绍了springboot设置了server.port但是没有用,还是8080问题的解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • java枚举类的属性、方法和构造方法应用实战

    java枚举类的属性、方法和构造方法应用实战

    这篇文章主要介绍了java枚举类的属性、方法和构造方法应用,结合实例形式分析了java枚举类的定义、构造及相关应用操作技巧,需要的朋友可以参考下
    2019-08-08
  • Java如何利用POI读取Excel行数

    Java如何利用POI读取Excel行数

    这篇文章主要介绍了java如何利用POI读取Excel行数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-02-02
  • IDEA实现远程调试步骤详解

    IDEA实现远程调试步骤详解

    这篇文章主要介绍了IDEA实现远程调试步骤详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • Java Spring boot 2.0 跨域问题的解决

    Java Spring boot 2.0 跨域问题的解决

    本篇文章主要介绍了Java Spring boot 2.0 跨域问题的解决,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-04-04
  • Java网络编程之简单的服务端客户端应用实例

    Java网络编程之简单的服务端客户端应用实例

    这篇文章主要介绍了Java网络编程之简单的服务端客户端应用,以实例形式较为详细的分析了java网络编程的原理与服务器端客户端的实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-04-04
  • Java 内部类的定义与范例

    Java 内部类的定义与范例

    说起内部类这个词,想必很多人都不陌生,但是又会觉得不熟悉。原因是平时编写代码时可能用到的场景不多,用得最多的是在有事件监听的情况下,并且即使用到也很少去总结内部类的用法。今天我们就来一探究竟
    2021-11-11
  • Springboot Mybatis-Plus数据库单元测试实战(三种方式)

    Springboot Mybatis-Plus数据库单元测试实战(三种方式)

    这篇文章主要介绍了Springboot Mybatis-Plus数据库单元测试实战(三种方式),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • Spring Boot配置接口WebMvcConfigurer的实现

    Spring Boot配置接口WebMvcConfigurer的实现

    这篇文章主要介绍了SpringBoot配置接口WebMvcConfigurer的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-11-11
  • Java8中List转Map的多种方式代码

    Java8中List转Map的多种方式代码

    这篇文章主要给大家介绍了关于Java8中List转Map的多种方式,在实际项目中我们经常会用到List转Map操作,本文介绍了多种方法的实现代码,需要的朋友可以参考下
    2023-08-08

最新评论