Skip to content

Commit e34eb87

Browse files
authored
Bael 5911 (#16299)
* BAEL-7490 read write file in separate thread * Change the to try resources * Update the code to sync with article * get next val * get next val
1 parent 2fca380 commit e34eb87

6 files changed

Lines changed: 121 additions & 0 deletions

File tree

Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,24 @@
1+
package com.baeldung.spring.data.jpa.getnextseq;
2+
3+
import javax.persistence.Entity;
4+
import javax.persistence.GeneratedValue;
5+
import javax.persistence.GenerationType;
6+
import javax.persistence.Id;
7+
import javax.persistence.SequenceGenerator;
8+
9+
@Entity
10+
public class MyEntity {
11+
12+
@Id
13+
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "mySeqGen")
14+
@SequenceGenerator(name = "mySeqGen", sequenceName = "my_sequence_name", allocationSize = 1)
15+
private Long id;
16+
17+
public Long getId() {
18+
return id;
19+
}
20+
21+
public void setId(Long id) {
22+
this.id = id;
23+
}
24+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
package com.baeldung.spring.data.jpa.getnextseq;
2+
3+
import org.springframework.boot.SpringApplication;
4+
import org.springframework.boot.autoconfigure.SpringBootApplication;
5+
6+
@SpringBootApplication
7+
public class MyEntityApplication {
8+
9+
public static void main(String[] args) {
10+
SpringApplication.run(MyEntityApplication.class);
11+
}
12+
13+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,12 @@
1+
package com.baeldung.spring.data.jpa.getnextseq;
2+
3+
import org.springframework.data.jpa.repository.JpaRepository;
4+
import org.springframework.data.jpa.repository.Query;
5+
import org.springframework.stereotype.Repository;
6+
7+
@Repository
8+
public interface MyEntityRepository extends JpaRepository<MyEntity, Long> {
9+
10+
@Query(value = "SELECT NEXTVAL('my_sequence_name')", nativeQuery = true)
11+
Long getNextSequenceValue();
12+
}
Lines changed: 22 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
package com.baeldung.spring.data.jpa.getnextseq;
2+
3+
import java.math.BigInteger;
4+
5+
import javax.persistence.EntityManager;
6+
import javax.persistence.PersistenceContext;
7+
8+
import org.springframework.stereotype.Service;
9+
10+
@Service
11+
public class MyEntityService {
12+
13+
@PersistenceContext
14+
private EntityManager entityManager;
15+
16+
public Long getNextSequenceValue(String sequenceName) {
17+
BigInteger nextValue = (BigInteger) entityManager.createNativeQuery("SELECT NEXTVAL(:sequenceName)")
18+
.setParameter("sequenceName", sequenceName)
19+
.getSingleResult();
20+
return nextValue.longValue();
21+
}
22+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,47 @@
1+
package com.baeldung.spring.data.jpa.getnextseq;
2+
3+
import static org.junit.Assert.assertEquals;
4+
import static org.junit.Assert.assertNotNull;
5+
6+
import org.junit.jupiter.api.Test;
7+
import org.springframework.beans.factory.annotation.Autowired;
8+
import org.springframework.boot.test.context.SpringBootTest;
9+
import org.springframework.test.context.ActiveProfiles;
10+
import org.springframework.test.context.jdbc.Sql;
11+
12+
@SpringBootTest
13+
@ActiveProfiles("test")
14+
@Sql(scripts = "/testsequence.sql", executionPhase = Sql.ExecutionPhase.BEFORE_TEST_METHOD)
15+
public class MyEntityRepositoryIntegrationTest {
16+
@Autowired
17+
private MyEntityRepository myEntityRepository;
18+
19+
@Autowired
20+
private MyEntityService myEntityService;
21+
22+
@Test
23+
void whenUsingSequenceGenerator_thenNextValueReturned() {
24+
MyEntity entity = new MyEntity();
25+
myEntityRepository.save(entity);
26+
27+
long generatedId = entity.getId();
28+
assertNotNull(generatedId);
29+
assertEquals(1L, generatedId);
30+
}
31+
32+
33+
@Test
34+
void whenUsingCustomQuery_thenNextValueReturned() {
35+
long generatedId = myEntityRepository.getNextSequenceValue();
36+
assertNotNull(generatedId);
37+
assertEquals(1L, generatedId);
38+
}
39+
40+
@Test
41+
void whenUsingEntityManager_thenNextValueReturned() {
42+
long generatedId = myEntityService.getNextSequenceValue("my_sequence_name");
43+
assertNotNull(generatedId);
44+
assertEquals(1L, generatedId);
45+
}
46+
47+
}
Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
DROP SEQUENCE IF EXISTS my_sequence_name;
2+
3+
CREATE SEQUENCE my_sequence_name START 1;

0 commit comments

Comments
 (0)