Oracle数据库与Access、SQL Server常见应用比较 |
本文标签:Oracle数据库 以下的文章主要是介绍Oracle数据库与Access、SQL Server、常见应用的比较,我在某公司做一个产品中,需要用到的有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:可以直接用
6、数据类型转换 A:CStr,CInt,CDate S:Convert O:To_Char,To_Number,To_Date 7、Inser Into …..Select …From 语句
这样的语句,在SQL Server以及Oracle数据库中都不会有错,但在Access中会报:INSERT INTO 语句的语法错误 。Access应该把后面Select语句的括号去掉,如下:
同时这样写在SQL Server和Oracle中都不会有错 8、关键字 有些字母在Access,SQL Server中是关键字,需要用[ ]界定可解决问题,例如:at,name 9、别名 SQL Server和Oracle中字段起别名时as可以省略,Access不能 10、表名前缀
这样的语句在Access,SQL Server中不会有错,但在Oracle数据库中是不行的,必须要写成这样:
11、如果语句中有:(冒号),例如有时间字段的查询:CalcDate=#2008-05-01 11:00:00#,在Access中一般会出现如下错误:不正常地定义参数对象 。提供了不一致或不完整的信息 。将相应Query的ParamCheck设为False即可 。 12、Access中的逻辑值在库中为-1和0,而SQL Server中为1和0,所以写BoolField = 1这样的语句有兼容性问题,应该改为BoolField <> 0 13、Access的varchar(文本)型最大只有255,所以如果一个文本型字段大于255时,最好定义成备注型(Access中)或text型(SQL Server中); |