Хотите закончить для l oop в RTF-шаблоне BI Publisher после 10 итераций - PullRequest
0 голосов
/ 28 апреля 2020

Хочу завершить для l oop в шаблоне RTF после 10 итераций. Может кто-нибудь, пожалуйста, подскажите мне об этом?

1 Ответ

0 голосов
/ 28 апреля 2020

Тестовые данные

<record_set>
<record>
<rownum>1</rownum>
<transaction_id>111</transaction_id>
<amount>200</amount>
</record>
<record>
<rownum>2</rownum>
<transaction_id>222</transaction_id>
<amount>300</amount>
</record>
<record>
<rownum>3</rownum>
<transaction_id>333</transaction_id>
<amount>400</amount>
</record>
<record>
<rownum>4</rownum>
<transaction_id>444</transaction_id>
<amount>200</amount>
</record>
</record_set>

Опция 1

Вы можете использовать переменную в операторе if.

<?for-each:record_set?>
<?xdoxslt:set_variable($_XDOCTX,'row_number',1)?>
<?for-each:record?><?if:xdoxslt:get_variable($_XDOCTX,'row_number')<=2?>
Transaction ID: <?transaction_id?>
Row Number: <?xdoxslt:get_variable($_XDOCTX,'row_number')?>
<?xdoxslt:set_variable($_XDOCTX,'row_number', xdoxslt:get_variable($_XDOCTX,'row_number')+1)?>
Amount:<?amount?>
<?end if?>
<?end for each?> 
<?end for each?>

Опция 2

Вы можете добавить rownum к вашему оператору выбора и XML, а затем использовать его в условии for-each.

select rownum, transaction_id, amount from your_table

<?for-each:record_set?>
<?for-each:record[rownum<=2]?>
Transaction ID: <?transaction_id?>
Row Number: <?rownum?>
Amount:<?amount?>
<?end for each?> 
<?end for each?>
...