在没有进入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}
我们知道%,_是like语句的通配符,如果我要查的内容本身包含'%'和'_'呢,比如一个字段的内容包含是分比.或axman_1这样的
内容,我想查出"axman_"有多少,怎么写?
SELECT x FROM table WHERE col LIKE 'axman//_%' {escape '//'},OK
存储过程(这个例是有人用过)
{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