2016/9/28

正則表示式筆記


  • 使用 String 的 replaceAll( String "Rex" , String "replace")時 , Rex 是找出符合正則表示式的目標  
    • 逗點 "." 代表任意字元 , 屬特殊字元
    • " \ " 為跳脫用
    • " \. " 此時仍為 java的特殊字元 的 "物件 . 方法"
    • " \\. " 此時為字串的" . " , 不屬特殊字元

2016/9/4

增進SQL查詢速度的方式 , SARGs


  • 最佳化where子句需符合 SARGs規範 , 否則DB易掃描所有資料影響查詢速度 ,  查詢速度也跟索引有關 , 為能利用索引搜尋資料 , 就要下正確的SQL方式 , 符合 SARGs規範 
  • Like不用%開頭當搜尋條件
    • 錯誤 select * from A where B like ' %2 '
  • 不對欄位做運算
    • 錯誤 select * from A where B+1='2'
    • 正確 select * from A where B='2'
  • 負向查詢
    • 錯誤 select * from A where B != 0
    • 正確 select * from A where B>0 and B<0
  • 不要對資料欄位使用函數
    • 錯誤1 select * from A where substring(B,1,1)='3'
    • 正確1 select * from A where B like '3%'
    • 正確1 select * from A where B >='3' and B < '4'
    • 錯誤2 select * from A where abs(A-100) <  1
    • 正確2 select * from A where B > 99 and B < 101 
  • 使用 OR 運算子查詢時 需每個欄位皆有索引 , 才能增進查詢速度

2016/9/2

[maven 7] 加入LOG4J


  • 參考網誌
  • Log4j 是一套開放源碼的工具,方便編程人員在程式中加入 log 機制,並輸出到各種目標上
  • 設定方式 , 可在server端設定 , 也可在project
    • properites
    • XML
  • 三大元件
    • Logger - 由編程人員在程式中使用,進行 logging 的元件
    • Appender - 負責將 log message 輸出到各種裝置上
    • Layout - 決定 log message 的格式
  • Logger  
    • 等級 : FATAL > ERROR > WARN > INFO > DEBUG
    • 當Logger設為 INFO時 , 只有比INFO高等級的結果才會被記錄下來 , 例如 FATAL、ERROR、WARN
  • Appender
    • 一個Logger物件可以同時輸出記錄到不同Appender(裝置)上
    • 一般情況 , 當子類別輸出紀錄時 , 父類別同時輸出相同訊息
  • Layout
    • %r [%t] %-5p %c - %m%n
    • 176 [main] INFO org.foo.Bar - Located nearest gas station.
    • PatternLayout 的 格式字元列表如下:
      • %c 輸出日誌訊息所屬的類別的全名
      • %d 輸出日誌時間點的日期或時間,指定格式的方式:%d{yyy-MM-dd HH:mm:ss }。
      • %l  輸出日誌事件的發生位置,即輸出日誌訊息的語句處於它所在的類別的第幾行。
      • %m 輸出訊息,如log(message)中的message。
      • %n 輸出一個列尾符號。
      • %p 輸出優先階層,即DEBUG,INFO,WARN,ERROR,FATAL。如果是調用debug()輸出的,則為DEBUG,依此類推。
      •  %r 輸出自應用啟動到輸出該日誌訊息所耗費的毫秒數。
      •  %t 輸出產生該日誌事件的線程名。
      •  %r 輸出自應用啟動到輸出該日誌訊息所耗費的毫秒數。
      •  %f 輸出日誌訊息所屬的類別的類別名。
  • 在pom.xml 貼入 log4j
  • 在web.xml 寫入 log4j 

  • 在src./main/resources目錄新增 log4j.properties
    • 設定logger等級為 INFO , 有console與syslog兩個appender
    • 其中syslog將把紀錄寫至 C:/usr/log/MyApp2.log裡
    • 輸出樣式可改變 ,  例如 11 、12行可互換 成 HTML樣式
  • 建立一支程式Log4j.java , 使用logger紀錄 INFO 
    • static : 此為靜態方法 , 不用實體化Log4j類別 , 即可呼叫 init方法   
    • Logger logger = Logger.getLogger(Log4j.class);
      •  產生logger物件時需要class名稱 Log4j 
    • logger.info("hello");
      •  程式讀到此行時 , 將 INFO訊息 hello 寫入 MyApp2.log

  • 在上一個單元 maven 6  的IndexController 類別塞入Log4j.init(); , 因為init 是靜態方法 , 不用先 new Log4j類別


  • 啟動專案後 ,   在網址列 送出 request 
    • http://localhost:8080/MyApp2/index1

  • 然後至 C:/usr/log/MyApp2.log 查看有無寫入即完成 , 且內容格式會按照log4j.properties  設定之方式呈現   , 以及hello 訊息









2016/9/1

[maven 6] 建立SpringMVC , 捨去Struts


  • 捨去 Struts ,專案使用之框架只有 Spring + Mybatis , 記得把 web.xml 與 pom.xml的 struts設定都拿掉

  • 此範例建立方式有兩種
    • XML設定
    • Annotation設定
  •  XML設定
    • 將 SpringMVC 加入 maven的 pom.xml 並update project
    • 在web.xml 新增SpringMVC的分派器 dispatcher , 告訴 web 我的request要由springMVC解析 , 此時原本的 application.xml 與 mvc-config.xml共存  , 或者可以將application 的檔案放置於 mvc-config.xml中將 application刪除
      • 依照下面的設定中則會讀取mvc-config.xml中的定義,檔案路經變更為 classpath底下。
      • 預設檔名:如果不設置 "contextConfigLocation"初始參數,xml檔名預設為「Servlet名稱- servlet.xml ,以下圖範例為 " SpringMVCServlet-servlet.xml "
      • 預設路徑:WEB-INF



    • 在Resources目錄下建立 mvc-config.xml檔案 , 且設定如下 , 
    • prefix是指 jsp檔案的路徑位置 , 也可設置在 WEB-INF底下 ,
    • suffix是指副檔名
    • bean name /index1 是指 url requet
    • 在這邊使用的是 spring的注入觀念 , set property  在程式的一端 將有一個setter 對應 , 將value menu/indexTest1 注入到 viewPage這個屬性




    • 程式端  , 在controller這個自定義的 package建立一個class ,並且 implement  spring的controller interface , 內容如下
      • 屬性 viewPage :回傳之 jsp 檔案與路徑
      • ModelAndView : 
        • 參數一 :回傳之 jsp 檔案與路徑
        • 參數二 :頁面變數或物件 ?
        • 參數三 :參數二內容

    • 建立menu目錄 , 建立 indexTest1.jsp , 並且接應 controller端的 user 


    • Spring MVC會將所有的Request先導向給一支叫做DispatcherServlet的程式,接著DispatcherServlet會決定要把這個Request交給哪個Controller做處理 
      • 以上組合的總結 : client 送出 request /index1 , spring 將${user}塞入 /menu/indexTest1.jsp 並送回client
      • XML設定方式預設會呼叫handleRequest方法 , 至於能不能改變就待個人去研究 , 往後不多磊述 , 此篇只是簡單實現MVC

  • Annotation設定
    • 與XML設定方法比較 ,  不需要設定bean name "/index1" , 直接透過寫annotation的方式即可完成MVC 
    • 需在mvc-config中啟動 annotation , 告訴annotation在哪
    • 建立 controller  Index2Controller
    • 建立 jsp indexTest2.jsp
    • 測試 : 當request 呼叫 /index2/add 時 , 會呼叫 class Index2Controller 的 add方法 , 將${user}資料塞入menu/indexTest2.jsp並回傳給client , 結果如下







test2