2013年7月19日 星期五

hsqldb - 如何擴展沒有的FUNCTION以適應其他sql ?

參考:src_jrt_routines

寫Test的時候遇到一個問題,我想在我的SQL Query中使用 LEN()這個mssql function:

 
  SELECT LEN(str) FROM TABLE where name='123'

然而由於寫Test時使用的並非mssql而是使用hsqldb,hsqldb並不支援LEN(),
而是使用LENGTH(),如果將我的SQL Query改為 LENGTH(),在正式上線時又會遇到
MS-SQL並沒有LENGTH()的問題....因此該怎麼做比較好呢??

原來hsqldb有擴展function的機制,就是為了預防這個問題的產生:

  1. create一個擴展的java class如下(注意function一定得為static,詳細使用對應的參數型別請參考上述參考頁):
  2.  
    package util.extend.mssql;
    
    public class MSSql {
     public static int len(String str) {
      return str.length();
     }
    }
    
  3. 並於實際執行有用到LEN的SQL Query的地方之前,使用下列SQL Query
     
          CREATE FUNCTION  len(str VARCHAR(20000))
            RETURNS INT 
     LANGUAGE JAVA DETERMINISTIC NO SQL
     EXTERNAL NAME 'CLASSPATH:util.extend.mssql.MSSql.len'
    

  4. 以上若完成,執行test,應該就能成功囉
這機制真是太方便了!!!

p.s話說回來完全找不到相關的中文討論阿....是說寫Test的人真的很少還是高手都直接找英文了呢....0rz...網路上查到的方式Create alias也是過時的方式,害我花了不少時間找...

沒有留言:

張貼留言