access oracle sql语句,Access、SQLServer、Oracle常见SQL语句应用区别

Access、sqlServer、Oracle常见sql语句应用区别

原作者:关劲松 PMP

日期:2011-10-14 15:31

来源:http://hi.baidu.com/okhymok/blog/item/c99132667ac5c258eaf8f8aa.html

搜集整理:sagahu@163.com

为了兼容Access、sql Server、Oracle三种数据库版,我们在编写sql语句的过程中,需要尽量使用一些通用的语句,但有些方面有些区别还是避免不了,现简单总结一下。

以下A代表Access,S代表sql Server,O代表Oracle:

1、取当前系统时间

A:Select Now()

S:Select Getdate()

O:Select Sysdate from Dual

2、连接字符串

A:&

S:+

O:||

3、字符串函数(截取字符串、大写、小写、查找字符串位置)

A:Mid、UCase、LCase、InStr

S:SubString、Upper、Lower、CharIndex

O:SubStr、Upper、Lower、InStr

4、判断取值语句

A:IIF

S:Case When Then

O:Decode

5、时间字段

A:要用#号分隔,或者转换为日期 SELECT * from Books WHERE RegDate = #2007-5-1#

SELECT * from Books WHERE RegDate = CDate(’2007-5-1′)

S:可以直接用'' SELECT * from Books WHERE RegDate = ‘2007-5-1′

O:To_Date SELECT * from Books WHERE RegDate=To_Date('2007-05-01','yyyy-mm-dd')

6、数据类型转换

A:CStr、CInt、CDate

S:Convert、CAST

O:To_Char、To_Number、To_Date

7、Inser Into …Select …from 语句

Insert Into a(ii,jj,kk) (Select ii,kk from b)

这样的语句,在sql Server以及Oracle中都不会有错,但在Access中会报:INSERT INTO 语句的语法错误。Access应该把后面Select语句的括号去掉,如下:

Insert Into a(ii,kk) Select ii,kk from b

同时这样写在sql Server和Oracle中都不会有错

8、关键字

有些字母在Access、sql Server中是关键字,需要用[ ]界定可解决问题,例如:at、name

9、别名

sql Server和Oracle中字段起别名时as可以省略,Access不能

10、表名前缀

Select *,1 from A

这样的语句在Access,sql Server中不会有错,但在Oracle中是不行的,必须要写成这样:

Select A.*,1 from A

11、如果语句中有:(冒号),例如有时间字段的查询:CalcDate=#2008-05-01 11:00:00#,在Access中一般会出现如下错误:不正常地定义参数对象。提供了不一致或不完整的信息。将相应Query的ParamCheck 设为False即可。

12、Access中的逻辑值在库中为-1和0,而sql Server中为1和0,所以写BoolField = 1这样的语句有兼容性问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值