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
957 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:

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:

// 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":

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!

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