Spring Data JPA 中Repository里的方法查询参数,判断是否为空

问题:

动态查询需要判断参数是否为空

方案:

查了一些资料,但是并没有完全解决掉,如果参数为null的时候,会直接报类型错误

如果后续解决会记录、如有大佬能解决可以留个足迹

SELECT
	md.ID,
	md.documentno,
	md.documenttitle,
	md.creator,
	md.issuingunit,
	md.issuetime,
	md.documentstatus,
	md.readingsituation,
	md.readingsituation,
	md.notes,
	md.documentcontent,
	md.updatetime,
	md.orgcode,
	md.districtcode,
	md.orgname 
FROM
	mine.mis_document AS md,
	( SELECT ID FROM mine.mis_document AS ms WHERE ms.issuingunit LIKE : CONDITION AND ms.documentstatus = '1' ) AS mn 
WHERE
	mn.ID = md.ID 
	AND ( : title IS NULL OR : title = '' OR md.documenttitle LIKE : title ) 
	//这个位置可以 : startTime IS NOT NULL 但是测试发现并没有生效
	AND ( : startTime IS NULL OR : startTime = '' OR to_char( md.issuetime, 'yyyy-MM-dd' ) >= : startTime ) 
	AND ( : endTime IS NULL OR : endTime = '' OR to_char( md.issuetime, 'yyyy-MM-dd' ) <= : endTime ) 
ORDER BY
	md.issuetime DESC

其他方法查询,但是对时间查询不是很友好

MisCoursePO mis = new MisCoursePO();
mis.setCoursetype("4");
mis.steCourseName("百科");
ExampleMatcher exampleMatcher = ExampleMatcher.matching()
               .withMatcher("courseName", GenericPropertyMatchers.contains()) //姓名采用“开始匹配”的方式查询
               .withIgnorePaths("id");  //忽略属性
Example<MisCoursePO> of = Example.of(mis, exampleMatcher);
List<MisCoursePO> list= misCourseDao.findAll(of);
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好,感谢您的提问。创建一个 Spring Data JPARepository 接口非常简单,只需要按照以下步骤操作即可: 1. 创建一个继承自 `JpaRepository` 的接口,指定实体类和主键类型: ``` public interface UserRepository extends JpaRepository<User, Long> { } ``` 其,`User` 是您的实体类,`Long` 是实体类的主键类型。`JpaRepository` 是 Spring Data JPA 提供的一个基础 Repository 接口,提供了一些基本的数据操作方法,如插入、删除、更新、查询等。 2. 在您的实体类上添注解,指定表名和主键: ``` @Entity @Table(name = "user") public class User { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String username; private String password; // 省略 getter 和 setter 方法 } ``` 在上述代码,`@Entity` 注解表示该类是一个 JPA 实体类,`@Table(name = "user")` 指定该实体类对应的数据库表名为 `user`,`@Id` 和 `@GeneratedValue` 注解指定实体类的主键。 3. 在您的 Spring Boot 应用程序,使用 `@EnableJpaRepositories` 注解启用 Spring Data JPA,并指定 Repository 接口的包路径: ``` @SpringBootApplication @EnableJpaRepositories(basePackages = "com.example.repository") public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } } ``` 在上述代码,`@EnableJpaRepositories` 注解用于启用 Spring Data JPA,`basePackages` 属性指定 Repository 接口的包路径。 4. 在您的服务层或控制器注入 Repository 接口,即可使用 Spring Data JPA 提供的基本数据操作方法: ``` @RestController public class UserController { @Autowired private UserRepository userRepository; @GetMapping("/users") public List<User> getAllUsers() { return userRepository.findAll(); } } ``` 在上述代码,`@Autowired` 注解用于自动注入 `UserRepository` 对象,然后在 `getAllUsers` 方法调用 `findAll` 方法获取所有用户信息。 通过上述步骤创建一个 Spring Data JPARepository 接口非常简单,希望能够帮助到您。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值