加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

Access、SQLServer、Oracle常见SQL语句应用区别

发布时间:2020-12-12 15:04:56 所属栏目:MsSql教程 来源:网络整理
导读:Access、SQLServer、Oracle常见SQL语句应用区别 - Access、SQLServer、Oracle常见SQL语句应用区别关劲松 PMP如果要兼容Access、SQL Server、Oracle三个数据库版本;我们在编写SQL语句的过程中,尽量使用一些通用的语句,但还是有些方面有些区别避免不了,现

Access、SQLServer、Oracle常见SQL语句应用区别
   -

Access、SQLServer、Oracle常见SQL语句应用区别关劲松 PMP如果要兼容Access、SQL Server、Oracle三个数据库版本;我们在编写SQL语句的过程中,尽量使用一些通用的语句,但还是有些方面有些区别避免不了,现简单总结一下。以下A代表Access,S代表SQL Server,O代表Oracle1、取当前系统时间A:Select Now()S:Select Getdate()O:Select Sysdate from Dual  2、连接字符串A:&S:+O:||  3、字符串函数(截取字符串、大写、小写、查找字符串位置)A:Mid、UCase、LCase、InStrS:SubString、Upper、Lower、CharIndexO:SubStr、Upper、Lower、InStr4、判断取值语句A:IIFS:Case When ThenO: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,CDateS:Convert,CASTO: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这样的语句有兼容性问题, ......

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读