집 >데이터 베이스 >MySQL 튜토리얼 >$P{} 및 $P!{} 구문을 사용하여 JasperReports 쿼리에 매개변수를 올바르게 전달하는 방법은 무엇입니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!