Access、SQLServer、Oracle常见的区别-AngelHis
Access软件网QQ交流学习群(群号码198465573),欢迎您的加入!
首页 >技术文章> Access数据库-模块/函数/VBA


Access、SQLServer、Oracle常见的区别

发表时间:2014/3/12 20:53:01 评论(2) 浏览(7263)  评论 | 加入收藏 | 复制
   
摘 要:      我们日常接触的数据库有Access、SQL Server、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

      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

      O:To_Char,To_Number,To_Date

      7、Inser Into …..Select …From 语句

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

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

      Insert Into a(ii,jj,kk) Select ii,jj,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这样的语句有兼容性问题,应该改为BoolField <> 0

      13、Access的varchar(文本)型最大只有255,所以如果一个文本型字段大于255时,最好定义成备注型(Access中)或text型(SQL Server中);


Access软件网交流QQ群(群号:198465573)
 
 相关文章
﹎. access连接ORACLE步骤 ﹎.  【Mrbig  2010/10/24】
Excel与access的大概区别  【麥田  2012/4/25】
SQL server与access的大概区别\什么是sqlserv...  【麥田  2012/4/25】
《基本医疗保险管理系统》我用Access+Oracle开发的作品照...  【在水一方  2012/7/26】
ACCESS网络连接到ORACLE数据库提取数据实例  【菜鸟先飞  2012/8/14】
Access、SQL Server、Oracle常见应用的区别  【宏鹏(转载)  2013/3/6】
【PPT教程】oracle基础  【网络收藏  2013/5/10】
Access转Oracle  【nivenm  2013/6/4】
access2013与2010区别  【红尘如烟  2014/3/12】
常见问答
技术分类
相关资源
文章搜索
关于作者

AngelHis

文章分类

文章存档

友情链接