本文主要是介绍JDBC中鲜为人知的中级应用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
在没有进入JDBC的高级应用前,我先来介绍一下一些"鲜为人知"的中级应用,说它是中级应用,因为对JDBC有所了解的人都应该知道,说它"鲜为人知",我却没有在任何人的代
码中或我所见过的任何讲JDBC的书中有提到过,非常奇怪,这本来是JDBC规范啊.
select * from table where datetimecol < now();这在mysql中可以正确运行.
可是在另的数据库呢?
select * from table where datatimecol < TO_DATE('yyyyMMMdd');
这在oracle中可以,在mysql中可以吗?是什么让这些SQL语句不能通用?是数据库
专用涵数,那么我们要在改变数据库后除了个性Driver还要改代码吗?
有没有通用的数据库涵数?有,只是我没见过几个人用过..................
到目前为止,JDBC其实都实现了 SQL-2 ENTRY Level,而SQL-2 Transitional Level
也基本实现(我没有用过没有实现的).只有实现上面的规范,JDBC就实现以下"通用"功能.它
会把这些通用的语义,标题,存储过程,涵数转化为数据库对应的功能,所以你只要掌握这些通
用语法在JDBC中应用,就不要再为特定数据库编写特定代码:
转义:{keyword parameter}
还记得oracle中插入?吗?
insert into table values ('aaa?aaa');什么?当然参数?不得不这样
insert into table values ('aaa' | '?' | 'aaa');把?专门作为一个字符再和其
它字符连结.用通用转义:
insert into table values ('aaa/?aaa') {escape /};
存储过程(这个例是有人用过)
{call procedure_Name[args]}
对于有返回值的存储过程
{? = call procedure_Name[args]}
时间和日期:
日期:{d 'yyyy-mm-dd'}
在任何数据库中,都会把你给定的yyyy-mm-dd转化为该数据的日期形式
insert into table values ('axman',{d '2003-07-28'});
在oracle中会转换成:Jul 28,2003
时间{t 'hh:mm:ss'},时间戳:{ts 'yyyy-mm-dd hh:mm:ss.f...'}
标量涵数:
{fn function([args])}
这个可要记住了,再也不要调用数据库特定涵数了,只要
insert into table values('axman',{fn CONCAT('1970-07-','11')});就可以在所有
实现SQL-2 Transitional Level的JDBC的数据库中运行,这些涵数要主包括:
数学涵数,字符串涵数,日期涵数,系统涵数,转换涵数,因为涵数大多,我没法一个个列
出来,请你用上面刚学习的DatabaseMetadata类调用getNumericFunctions(),getStringFunctions()
getSystemFunctions(),getTimeDateFunctions
这篇关于JDBC中鲜为人知的中级应用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!