Oracle数据库与Access、SQL Server常见应用比较

数据库 Oracle
下面的文章主要是介绍Oracle数据库与Access、SQL Server、常见应用的区别,以下就是文章的具体内容描述,希望你会有所收获。

以下的文章主要是介绍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:可以直接用''

 

  1. SELECT * FROM Books WHERE RegDate = ‘2007-5-1′  
  2. O:To_Date  
  3. 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 语句

 

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

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

 

  1. 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、表名前缀

 

  1. Select *,1 From A 

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

 

  1. 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中);

【编辑推荐】

  1. Oracle11生成AWR的实际相关报告简介
  2. Oracle case的实际用法总结
  3. Oracle 函数用法之decode解剖
  4. Oracle RAC配置的3步骤以及配置错误的原因
  5. Oracle字符集讨论的经典版
责任编辑:佚名 来源: 博客园
相关推荐

2011-08-25 16:50:20

SQL ServerAccessASP

2010-07-21 14:11:36

SQL Server

2011-05-26 14:07:11

SQL ServerOracle数据库镜像对比

2009-03-27 13:15:20

OracleSQL Server镜像

2009-08-03 14:17:18

C#连接AccessC#连接SQL Ser

2010-10-22 11:22:33

SQL Server数

2011-05-17 10:49:55

OracleSQL Server

2010-04-30 13:26:50

Oracle数据库

2022-11-04 08:34:27

Oracle数据库

2010-07-22 12:53:17

SQL Server数

2010-11-08 16:04:06

SQL SERVER连

2011-08-25 17:15:04

2009-11-18 16:16:51

Oracle数据库

2010-07-22 11:17:52

SQL Server数

2010-07-15 17:28:50

SQL Server

2010-07-22 11:01:41

SQL Server

2010-10-26 15:54:02

连接oracle数据库

2010-07-16 15:53:19

SQL Server数

2011-04-08 09:07:25

Access数据库Oracle库

2010-08-05 14:58:57

DB2数据库
点赞
收藏

51CTO技术栈公众号