反饋已提交

網絡繁忙

文字域元件實現多值查詢

1. 概述

1.1 版本

報表伺服器版本
功能變更
11.0-


1.2 預期效果

當使用者需要對表中的同一欄位實現多值查詢時,可以使用文字域元件。如下圖所示,當文字域參數有多個訂單 ID 時,查詢結果為多個訂單 ID 的資訊,如下圖所示:

1.3 實現思路

使用者可透過兩種方法實現文字域元件多值查詢,採用報表的過濾功能設定過濾條件,或透過 SQL 語句過濾。

2. 範例一:新增過濾條件實現

2.1 設計報表

1)建立普通報表,選擇「資料庫查詢」,新增資料集 ds1,SQL 語句為:SELECT * FROM 訂單

2)將資料集 ds1 的欄位拽入報表儲存格中,設計表格樣式。如下圖所示:

3)選中表格中的 A2 儲存格,點選「條件屬性」,點選「+」,屬性選擇「背景」,顏色選擇紫色,類型選擇「公式」,設定為「當前列」,公式為 row() % 2 = 0,點選「新增」。如下圖所示:

2.2 新增文字域元件

在參數面板中,新增「文字域元件」和「查詢按鈕」,將「文字域元件」元件名稱設定為 AK ,如下圖所示:

2.3 新增過濾

雙擊 A2 儲存格,點選「過濾」,類型選擇「公式」,公式內容為:INARRAY($$$, split($AK, "\n")) > 0,點選「新增」和「確認」。公式的作用為將文字域元件裏的文字,按照換列符進行分割,每列為一個查詢值,並匹配當前儲存格內容是否為文字域元件中輸入其中一個值。如下圖所示:

2.4 效果預覽

2.4.1 PC 端

儲存範本後,點選「分頁預覽」,在「文字域元件」中輸入訂單 ID ,PC 端效果如下圖所示:

2.4.2 行動端

3. 範例二:透過 SQL 語句實現

3.1 建立資料集

建立普通報表,選擇「資料庫查詢」,建立資料集 ds1 ,SQL 語句透過 in 查詢文字域元件中以換列輸入訂單 ID 的資料,並使資料在資料集中過濾。SQL 語句為:SELECT * FROM [訂單] where 1=1  ${if(len(AK)>0," and 訂單id in ('" +replace(AK, "\n","','")+ "')","")},公式的作用為調取表中訂單 id的值與參數AK的值相同的列,按照換列符進行分割,每列為一個查詢值。如下圖所示:

3.2 設計報表

1)將資料集 ds1 的欄位拽入報表儲存格中,設計表格樣式。

2)選中表格中的第 2 列,點選「條件屬性」點選「+」,屬性選擇「背景」,顏色選擇紫色,類型選擇「公式」,公式為 row() % 2 = 0,點選「新增」。如下圖所示:

3.3 新增參數元件

點選「參數面板」,選擇「全部新增」,選擇「文字域元件」,刪除「標籤元件」。如下圖所示:

3.4 效果預覽

1)儲存報表後,PC 端預覽效果,如 2.4 節所示。

2)App 及 HTML5 端預覽效果,如 2.4 節所示。

4. 注意事項

問題描述

有時使用者預設文字中含有多餘內容,需要只針對每條記錄中的部門內容進行過濾,這種情況直接查詢將會無法顯示。

解決方案

若預設文字中含有多餘內容,需要只針對每條記錄中的部門內容進行過濾,就需要對內容值進行處理,再進行資料過濾查詢。如下圖所示:

具體步驟如下所示:

在參數面板另外建立一個「文字域元件」用於對內容值進行處理,將第一個「文字域元件」的元件名稱為KKK ,元件值為「字串」;第二個「文字域元件」的元件名稱為AK ,元件值為「公式」,公式為:JOINARRAY(MAPARRAY(split($KKK,"\n"),INDEXOFARRAY(split(item,"-"),2)),"\n") 。如下圖所示:

儲存報表,點選「分頁預覽」即可。

5. 範本下載

附件列表


主題: 參數應用
  • 有幫助
  • 沒幫助
  • 只是瀏覽
  • 圖片不清晰
  • 用語看不懂
  • 功能說明看不懂
  • 操作說明太簡單
  • 內容有錯誤
中文(繁體)

滑鼠選中內容,快速回饋問題

滑鼠選中存在疑惑的內容,即可快速回饋問題,我們將會跟進處理。

不再提示

10s後關閉

獲取幫助
線上支援
獲取專業技術支援,快速幫助您解決問題
工作日9:00-12:00,13:30-17:30在线
頁面反饋
針對當前網頁的建議、問題反饋
售前咨詢
業務咨詢
電話:0933-790886或 0989-092892
郵箱:taiwan@fanruan.com
頁面反饋
*問題分類
不能為空
問題描述
0/1000
不能為空

反馈已提交

网络繁忙