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
Susan Sarandonasal
2024-12-22 17:46:14987semak imbas

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})

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 + "}");

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}

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