UserBalanceRepo.java 1.1 KB

1234567891011121314151617181920212223242526272829303132
  1. package com.izouma.nineth.repo;
  2. import com.izouma.nineth.domain.UserBalance;
  3. import org.springframework.data.jpa.repository.JpaRepository;
  4. import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
  5. import org.springframework.data.jpa.repository.Modifying;
  6. import org.springframework.data.jpa.repository.Query;
  7. import javax.transaction.Transactional;
  8. import java.math.BigDecimal;
  9. import java.util.List;
  10. import java.util.Optional;
  11. public interface UserBalanceRepo extends JpaRepository<UserBalance, Long>, JpaSpecificationExecutor<UserBalance> {
  12. List<UserBalance> findByBalanceGreaterThan(BigDecimal balance);
  13. List<UserBalance> findByLockedFalseAndBalanceGreaterThanOrderByUserId(BigDecimal balance);
  14. @Query("update UserBalance u set u.locked = false, u.lockTime = null, u.lockReason = null where u.userId = ?1")
  15. @Modifying
  16. @Transactional
  17. int unlock(Long userId);
  18. Optional<UserBalance> findByUserId(Long userId);
  19. @Modifying
  20. @Transactional
  21. @Query("update UserBalance b set b.balance = b.balance + ?2 where b.userId = ?1")
  22. void modifyBalance(Long userId, BigDecimal amount);
  23. }