cari
RumahJavajavaTutorialKaedah Pertanyaan Strim JPA Data Spring

Spring Data JPA Stream Query Methods

pengenalan

Secara tradisinya, mengambil sejumlah besar data boleh membebankan sumber memori, kerana ia selalunya melibatkan pemuatan keseluruhan set hasil ke dalam memori.

=> Kaedah pertanyaan strim menawarkan penyelesaian dengan menyediakan cara untuk memproses data secara berperingkat menggunakan Java 8 Streams. Ini memastikan bahawa hanya sebahagian daripada data disimpan dalam ingatan pada bila-bila masa, meningkatkan prestasi dan kebolehskalaan.

Dalam catatan blog ini, kami akan mendalami cara kaedah pertanyaan strim berfungsi dalam Spring Data JPA, meneroka kes penggunaannya dan menunjukkan pelaksanaannya.

Untuk panduan ini, kami menggunakan:

  • IDE: IntelliJ IDEA (disyorkan untuk aplikasi Spring) atau Eclipse
  • Versi Java: 17
  • Spring Data JPA Versi: 2.7.x atau lebih tinggi (serasi dengan Spring Boot 3.x)
<dependency>
    <groupid>org.springframework.boot</groupid>
    <artifactid>spring-boot-starter-data-jpa</artifactid>
</dependency>

NOTA: Untuk contoh yang lebih terperinci, sila lawati repositori GitHub saya di sini

1. Apakah Kaedah Pertanyaan Strim?

Kaedah pertanyaan strim dalam Spring Data JPA membolehkan kami mengembalikan hasil pertanyaan sebagai Strim dan bukannya Senarai atau jenis koleksi lain. Pendekatan ini memberikan beberapa faedah:

  • Pengurusan Sumber yang Cekap: Data diproses secara berperingkat, mengurangkan overhed memori.

  • Malas Memproses: Keputusan diambil dan diproses atas permintaan, yang sesuai untuk senario seperti penomboran atau pemprosesan kelompok.

  • Integrasi dengan Pengaturcaraan Fungsian: Strim sesuai dengan ciri pengaturcaraan berfungsi Java, membolehkan operasi seperti penapis, peta dan pengumpulan.

2. Bagaimana Untuk Menggunakan Kaedah Pertanyaan Strim?

=> Bayangkan kita sedang membangunkan aplikasi e-dagang dan ingin:

  • Dapatkan semula semua pelanggan yang membuat pesanan selepas tarikh tertentu.
  • Tapis pesanan dengan jumlah keseluruhan melebihi jumlah tertentu yang disediakan.
  • Kumpulkan pelanggan mengikut jumlah nilai pesanan mereka dalam tempoh 6 bulan yang lalu.
  • Kembalikan data sebagai ringkasan nama pelanggan dan jumlah nilai pesanan mereka.

Entiti

  • Pelanggan: Mewakili pelanggan.
@Setter
@Getter
@Entity
@Entity(name = "tbl_customer")
public class Customer {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    private String name;
    private String email;

    @OneToMany(mappedBy = "customer", cascade = CascadeType.ALL, fetch = FetchType.LAZY)
    private List<order> orders;
}
</order>
  • Pesanan: Mewakili pesanan yang dibuat oleh pelanggan.
@Setter
@Getter
@Entity(name = "tbl_order")
public class Order {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    private Double amount;
    private LocalDateTime orderDate;

    @ManyToOne
    @JoinColumn(name = "customer_id")
    private Customer customer;
}

Repositori

  • CustomerRepository digunakan untuk memilih pelanggan dan pesanan berkaitan mereka dibuat selepas tarikh tertentu. Dan kami menggunakan Stream bukannya Senarai untuk mengendalikan hasil pertanyaan.
public interface CustomerRepository extends JpaRepository<customer long> {
    @Query("""
                SELECT c FROM tbl_customer c JOIN FETCH c.orders o WHERE o.orderDate >= :startDate
            """)
    @QueryHints(
            @QueryHint(name = AvailableHints.HINT_FETCH_SIZE, value = "25")
    )
    Stream<customer> findCustomerWithOrders(@Param("startDate") LocalDateTime startDate);
}
</customer></customer>

NOTA:

  • JOIN FETCH memastikan pesanan dimuatkan dengan penuh semangat.

  • @QueryHints yang digunakan untuk memberikan pembayang tambahan kepada JPA menyediakan (cth. Hibernate) untuk mengoptimumkan pelaksanaan pertanyaan.

=> Contohnya, apabila pertanyaan saya mengembalikan 100 rekod:

  • 25 rekod pertama diambil dan diproses oleh aplikasi.
  • Setelah diproses, 25 rekod seterusnya akan diambil, dan seterusnya, sehingga kesemua 100 rekod diproses.
  • Tingkah laku ini meminimumkan penggunaan memori dan mengelakkan memuatkan kesemua 100 rekod ke dalam memori sekaligus.

Perkhidmatan

<dependency>
    <groupid>org.springframework.boot</groupid>
    <artifactid>spring-boot-starter-data-jpa</artifactid>
</dependency>

Berikut ialah kelas perkhidmatan untuk memproses data dengan dua parameter startDate dan minOrderAmount. Seperti yang anda lihat, kami tidak menapis dengan menggunakan pertanyaan sql dan memuatkan semua data sebagai strim kemudian menapis dan mengumpulkan mengikut kod Java kami.

Pengawal

@Setter
@Getter
@Entity
@Entity(name = "tbl_customer")
public class Customer {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    private String name;
    private String email;

    @OneToMany(mappedBy = "customer", cascade = CascadeType.ALL, fetch = FetchType.LAZY)
    private List<order> orders;
}
</order>

Ujian

=> Untuk membuat data untuk ujian, anda boleh melaksanakan skrip berikut di dalam kod sumber saya atau menambah sendiri.

src/main/resources/dummy-data.sql

Permintaan:

  • Tarikh mula: 2024-05-01T00:00:00
  • minAmaun Pesanan: 100
@Setter
@Getter
@Entity(name = "tbl_order")
public class Order {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    private Double amount;
    private LocalDateTime orderDate;

    @ManyToOne
    @JoinColumn(name = "customer_id")
    private Customer customer;
}

Jawapan:

  • Pulangan semua pelanggan dengan jumlah amaun mereka yang sama atau lebih besar daripada minOrderAmount.
public interface CustomerRepository extends JpaRepository<customer long> {
    @Query("""
                SELECT c FROM tbl_customer c JOIN FETCH c.orders o WHERE o.orderDate >= :startDate
            """)
    @QueryHints(
            @QueryHint(name = AvailableHints.HINT_FETCH_SIZE, value = "25")
    )
    Stream<customer> findCustomerWithOrders(@Param("startDate") LocalDateTime startDate);
}
</customer></customer>

3. Strim vs Senarai

=> Anda boleh menggunakan IntelliJ Profiler untuk memantau penggunaan memori dan masa pelaksanaan. Untuk butiran lanjut tentang cara menambah dan menguji dengan set data yang besar, anda boleh temui dalam repositori GitHub saya

Set Data Kecil: (10 pelanggan, 100 pesanan)

  • Strim: Masa pelaksanaan (~5ms), Penggunaan memori (Rendah)
  • Senarai: Masa pelaksanaan (~4ms), Penggunaan memori (Rendah)

Set Data Besar (10.000 pelanggan, 100.000 pesanan)

  • Strim: Masa pelaksanaan (~202ms), Penggunaan memori (Sederhana)
  • Senarai: Masa pelaksanaan (~176ms), Penggunaan memori (Tinggi)

Metrik Prestasi

Metric Stream List
Initial Fetch Time Slightly slower (due to lazy loading) Faster (all at once)
Memory Consumption Low (incremental processing) High (entire dataset in memory)
Memory Consumption Low (incremental processing) High (entire dataset in memory)
Processing Overhead Efficient for large datasets May cause memory issues for large datasets
Batch Fetching Supported (with fetch size) Not applicable
Error Recovery Graceful with early termination Limited, as data is preloaded

Membungkus

Kaedah pertanyaan aliran JPA Data Musim Bunga menawarkan cara yang elegan untuk memproses set data yang besar dengan cekap sambil memanfaatkan kuasa Java Stream. Dengan memproses data secara berperingkat, ia mengurangkan penggunaan memori dan menyepadukan dengan lancar dengan paradigma pengaturcaraan berfungsi moden.

Apakah pendapat anda tentang kaedah pertanyaan strim? Kongsi pengalaman dan kes penggunaan anda dalam ulasan di bawah!

Jumpa anda dalam siaran seterusnya. Selamat Mengekod!

Atas ialah kandungan terperinci Kaedah Pertanyaan Strim JPA Data Spring. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Bagaimanakah saya menggunakan Maven atau Gradle untuk Pengurusan Projek Java Lanjutan, Membina Automasi, dan Resolusi Ketergantungan?Bagaimanakah saya menggunakan Maven atau Gradle untuk Pengurusan Projek Java Lanjutan, Membina Automasi, dan Resolusi Ketergantungan?Mar 17, 2025 pm 05:46 PM

Artikel ini membincangkan menggunakan Maven dan Gradle untuk Pengurusan Projek Java, membina automasi, dan resolusi pergantungan, membandingkan pendekatan dan strategi pengoptimuman mereka.

Bagaimanakah saya membuat dan menggunakan perpustakaan Java Custom (fail JAR) dengan pengurusan versi dan pergantungan yang betul?Bagaimanakah saya membuat dan menggunakan perpustakaan Java Custom (fail JAR) dengan pengurusan versi dan pergantungan yang betul?Mar 17, 2025 pm 05:45 PM

Artikel ini membincangkan membuat dan menggunakan perpustakaan Java tersuai (fail balang) dengan pengurusan versi dan pergantungan yang betul, menggunakan alat seperti Maven dan Gradle.

Bagaimanakah saya melaksanakan caching pelbagai peringkat dalam aplikasi java menggunakan perpustakaan seperti kafein atau cache jambu?Bagaimanakah saya melaksanakan caching pelbagai peringkat dalam aplikasi java menggunakan perpustakaan seperti kafein atau cache jambu?Mar 17, 2025 pm 05:44 PM

Artikel ini membincangkan pelaksanaan caching pelbagai peringkat di Java menggunakan kafein dan cache jambu untuk meningkatkan prestasi aplikasi. Ia meliputi persediaan, integrasi, dan faedah prestasi, bersama -sama dengan Pengurusan Dasar Konfigurasi dan Pengusiran PRA Terbaik

Bagaimanakah saya boleh menggunakan JPA (Java Constence API) untuk pemetaan objek-objek dengan ciri-ciri canggih seperti caching dan malas malas?Bagaimanakah saya boleh menggunakan JPA (Java Constence API) untuk pemetaan objek-objek dengan ciri-ciri canggih seperti caching dan malas malas?Mar 17, 2025 pm 05:43 PM

Artikel ini membincangkan menggunakan JPA untuk pemetaan objek-relasi dengan ciri-ciri canggih seperti caching dan pemuatan malas. Ia meliputi persediaan, pemetaan entiti, dan amalan terbaik untuk mengoptimumkan prestasi sambil menonjolkan potensi perangkap. [159 aksara]

Bagaimanakah mekanisme kelas muatan Java berfungsi, termasuk kelas yang berbeza dan model delegasi mereka?Bagaimanakah mekanisme kelas muatan Java berfungsi, termasuk kelas yang berbeza dan model delegasi mereka?Mar 17, 2025 pm 05:35 PM

Kelas kelas Java melibatkan pemuatan, menghubungkan, dan memulakan kelas menggunakan sistem hierarki dengan bootstrap, lanjutan, dan pemuat kelas aplikasi. Model delegasi induk memastikan kelas teras dimuatkan dahulu, yang mempengaruhi LOA kelas tersuai

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

SecLists

SecLists

SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

PhpStorm versi Mac

PhpStorm versi Mac

Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)