隨筆 - 225  文章 - 98  trackbacks - 0
          <2013年6月>
          2627282930311
          2345678
          9101112131415
          16171819202122
          23242526272829
          30123456

          隨筆分類

          相冊

          報表工具廠商們

          搜索

          •  

          最新評論

          閱讀排行榜

           

          1. 問題描述

          客戶的用戶群體很大,涵蓋范圍很廣,為了數(shù)據(jù)安全,所以將不同區(qū)域的數(shù)據(jù)存在不同的數(shù)據(jù)庫中。同時考慮到開發(fā)工作和后期的維護(hù)等,將這些數(shù)據(jù)的業(yè)務(wù)在同一張表里顯示(這些業(yè)務(wù)關(guān)系一樣,在數(shù)據(jù)庫中表的字段都一樣)。所以在數(shù)據(jù)錄入時,需要根據(jù)用戶所在的區(qū)域,將用戶錄入的數(shù)據(jù)存入不同的數(shù)據(jù)庫表中。

          2. 解決思路

          在模板中建幾個隱藏的按鈕控件,分別設(shè)置提交事件,觸發(fā)提交入庫,再在工具欄上或者模板中設(shè)置自定義按鈕,編寫js,根據(jù)不同的參數(shù)觸發(fā)不同的按鈕,實(shí)現(xiàn)根據(jù)不同的參數(shù)提交到對應(yīng)的數(shù)據(jù)庫功能。

          3. 示例

          我們的FRDemo數(shù)據(jù)庫中有2張表S訂單和訂單,這兩張表的數(shù)據(jù)結(jié)構(gòu)一模一樣,選擇華東,華中,華北地區(qū)的數(shù)據(jù)時,數(shù)據(jù)填入數(shù)據(jù)庫S訂單,選擇其他地區(qū)時,數(shù)據(jù)填入數(shù)據(jù)庫訂單

          3.1 數(shù)據(jù)準(zhǔn)備

          新建模板,新建數(shù)據(jù)集ds1:SELECT * FROM [訂單] where 貨主地區(qū)='${地區(qū)}'

          3.2 參數(shù)界面設(shè)置

          切換到參數(shù)設(shè)計界面,將地區(qū)參數(shù)的控件添加到面板中,數(shù)據(jù)字典設(shè)置如下:


          3.3 報表主體設(shè)計

          這里為了簡潔方便,只添加了幾個控件,并沒有將所有數(shù)據(jù)列都添加一個控件,如下圖:


          其中第5行中為填報控件,控件設(shè)置如下表:

          控件類型

          數(shù)據(jù)字典

          B5

          文本框

          C5

          下拉框

          來源于客戶表,實(shí)際值客戶ID,顯示值公司名稱

          D5

          下拉框

          來源于雇員表,實(shí)際值雇員ID,顯示值姓名

          E5

          文本框

          wu

          F5

          下拉框

          公式:sql("FRDemo", "select 貨主城市 from 訂單 where 貨主地區(qū)='" + $地區(qū) + "'", 1)

          3.4 按鈕設(shè)置

          如上圖,第2行中的三個按鈕分別為進(jìn)行提交入庫操作的2個隱藏按鈕和一個進(jìn)行點(diǎn)擊操作的可見按鈕。

          · E2單元格

          控件名為“s”,該控件控制S訂單表的填報,添加一個點(diǎn)擊事件,事件類型選擇提交入庫,如下圖:


          · 
          F2單元格

          控件名為“S1”,該控件控制訂單表的填報,添加一個點(diǎn)擊事件,事件類型選擇提交入庫,如下圖:


          將E2單元格和F2單元格中的按鈕都設(shè)置為不可見。

          · H2單元格

          給該按鈕添加一個點(diǎn)擊事件,如下圖:


          完整js如下:

          1. var s=contentPane.getWidgetByName("s");  

          2. var s1=contentPane.getWidgetByName("s1");  

          3. if(area=='華東'||area=='華北'||area=='華中')  

          4. s.fireEvent("click");  

          5. else  

          6. s1.fireEvent("click");  

          該提交按鈕也可自定在工具欄中,設(shè)置過程一樣。

          3.5 效果查看

          點(diǎn)擊填報預(yù)覽,參數(shù)選擇華東,效果如下圖:參數(shù)選擇西南,效果如下圖:


          注:此例中由于數(shù)據(jù)的限制,只用了2張數(shù)據(jù)表進(jìn)行填報,如果有多張表,則需要設(shè)置多個隱藏按鈕。



          了解Java報表工具就從這里開始
          posted on 2013-06-15 23:09 season 閱讀(1234) 評論(0)  編輯  收藏 所屬分類: Java報表—技術(shù)知識Java報表—使用心得
          主站蜘蛛池模板: 施秉县| 达尔| 鄂尔多斯市| 独山县| 政和县| 荥阳市| 密云县| 玛纳斯县| 惠东县| 巩留县| 青阳县| 科技| 金溪县| 揭东县| 万盛区| 锦屏县| 龙州县| 麦盖提县| 高邑县| 临猗县| 昌平区| 大同县| 丰台区| 科技| 清镇市| 山东省| 七台河市| 苏尼特右旗| 玉林市| 嘉善县| 杭州市| 靖边县| 周宁县| 湾仔区| 平顶山市| 六安市| 迭部县| 平谷区| 响水县| 宿州市| 郯城县|