Access、SQLServer、Oracle常见SQL语句应用区别
Access、SQLServer、Oracle常见SQL语句应用区别?
? 如果要兼容Access、SQL Server、Oracle三个数据库版本;我们在编写SQL语句的过程中,尽量使用一些通用的语句,但还是有些方面有些区别避免不了,现简单总结一下。 以下A代表Access,S代表SQL Server,O代表Oracle ?点击打开链接 1、取当前系统时间 A:Select Now() S:Select Getdate() O:Select Sysdate From Dual A:& S:+ O:|| A:Mid、UCase、LCase、InStr S:SubString、Upper、Lower、CharIndex O:SubStr、Upper、Lower、InStr
A:IIF S:Case When Then O:Decode 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')
A:CStr,CInt,CDate S:Convert,CAST O:To_Char,To_Number,To_Date 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中都不会有错 有些字母在Access,SQL Server中是关键字,需要用[ ]界定可解决问题,例如:at,name SQL Server和Oracle中字段起别名时as可以省略,Access不能 Select *,1 From A 这样的语句在Access,SQL Server中不会有错,但在Oracle中是不行的,必须要写成这样: Select A.*,1 From A Query的ParamCheck 设为False即可。 13、Access的varchar(文本)型最大只有255,所以如果一个文本型字段大于255时,最好定义成备注型(Access中)或text型(SQL Server中)。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |