> 데이터 베이스 > MySQL 튜토리얼 > $P{} 및 $P!{} 구문을 사용하여 JasperReports 쿼리에 매개변수를 올바르게 전달하는 방법은 무엇입니까?

$P{} 및 $P!{} 구문을 사용하여 JasperReports 쿼리에 매개변수를 올바르게 전달하는 방법은 무엇입니까?

DDD
풀어 주다: 2025-01-18 06:31:08
원래의
643명이 탐색했습니다.

How to Properly Pass Parameters to JasperReports Queries Using $P{} and $P!{} Syntax?

JasperReports 쿼리 매개변수 전달

데이터베이스 쿼리에서는 사용자 입력에 따라 매개변수를 동적으로 전송하는 것이 일반적인 요구 사항입니다. 일부 사용자는 $P{} 구문을 사용하여 매개변수를 전달할 때 문제가 발생할 수 있습니다.

JasperReports는 매개변수 참조를 위한 두 가지 구문인 $P{}$P!{}을 제공합니다.

$P{paramName} 문법

$P{paramName}은 주로 WHERE 절의 입력 매개변수 값을 설정하는 데 사용됩니다. 이 구문의 대체 알고리즘은 java.sql.PreparedStatement과 유사합니다. 다양한 매개변수 유형을 지능적으로 처리합니다.

  • java.lang.String 유형 매개변수의 경우 엔진은 $P{parameterName}을 인용된 값으로 바꿉니다.
  • java.lang.Integer 유형 매개변수의 경우 엔진은 $P{parameterName}을 숫자 값으로 바꿉니다.

예:

参数名称 参数类型 参数值
eventName java.lang.String Olympic Games
eventType java.lang.Integer 2

원래 표현:

<code class="language-sql">SELECT startDate, endDate, rating FROM events WHERE name=$P{eventName} AND type=$P{eventType}</code>
로그인 후 복사

결과:

<code class="language-sql">SELECT startDate, endDate, rating FROM events WHERE name='Olympic Games' AND type=2</code>
로그인 후 복사

$P!{paramName} 문법

$P!{paramName} 구문은 일반적으로 인수의 정확한 값을 바꾸는 데 사용되는 간단한 대체를 수행합니다.

예:

参数名称 参数类型 参数值
tableName java.lang.String events
eventName java.lang.String Olympic Games
channel java.lang.String 'BBC'
type java.lang.String sport

원래 표현:

<code class="language-sql">SELECT startDate, endDate, rating FROM $P!{tableName} WHERE name='$P!{eventName}' AND channel=$P!{channel} AND type=$P!{type}</code>
로그인 후 복사

결과:

<code class="language-sql">SELECT startDate, endDate, rating FROM events WHERE name='Olympic Games' AND channel='BBC' AND type=sport</code>
로그인 후 복사

질문에 적용

주어진 쿼리에 대해 다음 표현식이 적용될 수 있습니다.

  • $P{key}java.lang.String인 경우 매개변수 유형:
<code class="language-sql">SELECT name, phone, email FROM company WHERE $P!{clause} = $P{key} ORDER BY $P!{order}</code>
로그인 후 복사
  • $P{key}이 문자열이 아닌 유형 매개변수인 경우:
<code class="language-sql">SELECT name, phone, email FROM company WHERE $P!{clause} = $P!{key} ORDER BY $P!{order}</code>
로그인 후 복사

위 내용은 $P{} 및 $P!{} 구문을 사용하여 JasperReports 쿼리에 매개변수를 올바르게 전달하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿