SpringBoot--JPA的Dao层问题记录

在JPA中定义了一些默认的接口,并且支持一些SQL语法中的关键字,如 AND、BETWEEN等,因此,如果自己写了一个findByUId(Integer id);的方法,并且配了一个@Query注解,就会引发一个非法参数和Dao层的对象初始化异常的问题。

解决的方式有两种:

1、避免自定义的方法与JPA支持的写法冲突,比如写 getById(Integer id);

2、去掉@Query注解,直接写一个 findById(int id);这个写法等同于执行 select * from [table] by id; 这样的SQL语句

 

其他还有 findByName 等同理。

findBy 语法参考:

https://www.jianshu.com/p/67ee279530b8

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot 是一个基于 Java 的全栈框架,用于简化 Spring 应用程序的开发流程。它包含了一套完整的工具集和约定,在不影响应用功能的前提下减少了大量的配置工作。在 Spring Boot 中,应用程序通常分为三个核心组件: ### 1. 控制(Controller ) 控制也称为 MVC(Model View Controller)模式的控制器部分。它的职责在于处理来自前端的 HTTP 请求,并通过调用业务方法响应请求。控制与视图交互,生成并返回 HTML、JSON 或其他格式的数据给用户界面。 #### 关于主键 在 Spring Boot 的上下文中,主键通常是指数据库表中的唯一标识符字段,它是数据持久化时用于区分记录的关键信息。例如,在关系型数据库中常见的 `id` 字段就是一种主键形式,而在 NoSQL 数据库中可能会有类似 `_id` 等字段作为主键。在 Spring Data JPA(用于操作实体对象的标准库)中,通常可以自动生成主键策略,比如使用 UUID 或者简单的自增整数等。 ### 2. 业务(Service ) 业务是将数据逻辑从控制分离出来的一个次。它负责封装具体的业务逻辑,包括但不限于数据验证、业务规则检查、数据转换以及与持久交互等。业务应当保持高度的抽象性和可复用性,避免依赖特定的数据库实现细节。 #### 主键作用 在业务中,当需要从持久获取或更新数据时,主键扮演着关键角色。业务通常会使用实体类的主键属性作为查条件,执行诸如查询、添加、删除或更新操作。因此,理解主键对于业务逻辑的设计至关重要。 ### 3. 持久(Repository/DAO ) 持久主要是对数据存储进行抽象化的,它可以是 ORM 工具如 Hibernate 或者直接操作 SQL 的方式。在这个面上,关注点是如何与数据库交互,完成数据的读取、插入、更新和删除操作。 #### 主键管理 在持久中,主键的生成和管理通常是自动完成的。对于大多数情况下,ORM 工具会提供主键生成策略,例如自增长(对于关系型数据库)、UUID 自动生成等。开发者只需要指定实体类中有无主键即可,其余的策略由工具负责实现。 #### 实现示例 在使用 Spring Data JPA 开发项目时,可以在实体类上定义主键属性,通常会标注为 `@Id`,并且可以设置主键生成策略,比如使用 `@GeneratedValue(strategy = GenerationType.IDENTITY)` 来表示使用数据库内部的主键生成机制(如自增)。在 Repository 接口中不需要特别关注主键的生成,因为 Spring Data 自动管理和处理这些细节。 --- --- 相关问题 ---: 1. 怎么在 Spring Boot 项目中设计控制? 2. Spring Boot 中如何实现业务逻辑分? 3. 如何在 Spring Data JPA自定义主键生成策略?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值