Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Lulus Senarai Parameter Pembolehubah kepada Predikat SQL 'IN' JasperReports?

Bagaimana untuk Lulus Senarai Parameter Pembolehubah kepada Predikat SQL 'IN' JasperReports?

Susan Sarandon
Lepaskan: 2024-12-22 17:46:14
asal
926 orang telah melayarinya

How to Pass a Variable Parameter List to JasperReports' SQL

Melalui Senarai Parameter Pembolehubah dalam JasperReports menggunakan Predikat SQL "IN"

Apabila bekerja dengan JasperReports dan predikat SQL "IN", ia adalah perlu untuk menghantar senarai parameter kepada pertanyaan secara dinamik. Artikel ini menunjukkan cara untuk menetapkan nilai parameter yang mengandungi senarai nilai integer dalam program Java.

Pertanyaan SQL di bawah memerlukan senarai parameter "peranan" yang mengandungi satu atau lebih nilai integer:

1

2

3

4

SELECT customer_name AS NAME,

       id_customer   AS ID

  FROM customer

 WHERE customer_role IN ($P{roles})

Salin selepas log masuk

Untuk menetapkan nilai parameter "peranan" secara dinamik dalam Java, gunakan pembolehubah "$X" yang disediakan oleh JasperReports:

1

2

3

4

5

6

7

8

// Assume the "roles" parameter is a list of integers

List<Integer> roles = ...;

 

// Convert the list to a comma-separated string

String roleString = roles.stream().map(String::valueOf).collect(Collectors.joining(","));

 

// Set the parameter value using the "$X" variable

parameters.put("roles", "$X{IN,customer-role," + roleString + "}");

Salin selepas log masuk

Menggunakan sintaks "$X{IN,column-name,parameter-name}" membolehkan anda menentukan lajur untuk dibandingkan, nama parameter dan senarai nilai.

Sebagai contoh, pertanyaan berikut akan menggunakan parameter "peranan" untuk menapis lajur yang dipanggil "customer_role":

1

2

3

SELECT *

  FROM customer

 WHERE $X{IN,customer_role,roles}

Salin selepas log masuk

Penyelesaian ini membolehkan anda menghantar senarai parameter dinamik kepada predikat SQL "IN" dalam JasperReports, memastikan pertanyaan menapis data dengan betul berdasarkan nilai yang diberikan.

Atas ialah kandungan terperinci Bagaimana untuk Lulus Senarai Parameter Pembolehubah kepada Predikat SQL 'IN' JasperReports?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan