寫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的機制,就是為了預防這個問題的產生:
- create一個擴展的java class如下(注意function一定得為static,詳細使用對應的參數型別請參考上述參考頁):
- 並於實際執行有用到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'
- 以上若完成,執行test,應該就能成功囉
package util.extend.mssql; public class MSSql { public static int len(String str) { return str.length(); } }
這機制真是太方便了!!!
p.s話說回來完全找不到相關的中文討論阿....是說寫Test的人真的很少還是高手都直接找英文了呢....0rz...網路上查到的方式Create alias也是過時的方式,害我花了不少時間找...
p.s話說回來完全找不到相關的中文討論阿....是說寫Test的人真的很少還是高手都直接找英文了呢....0rz...網路上查到的方式Create alias也是過時的方式,害我花了不少時間找...
沒有留言:
張貼留言