天天看点

Oracle 与 Access 的不同点

一、建表语句中的差别

Oracle                    Access

Date                         DateTime

varchar2()                    varchar()

Varchar2(256)                MEMO  (varchar最大长度255,再大就改用MEMO)

 NUMBER(1)                 SmallInt

NUMBER(16,2)               decimal(16,2)

BLOB                        IMAGE

NULL                        什么都不写

--(注释)                    没有此功能

comment                     没有此功能

using index tablespace ……    什么都不写

关键字可以作为字段名         关键字不能作为字段名称,如:RIGHT、Key、Value等

二、修改表

alter也不同

Delete语句 :Access必须加入from

Access不需要commit;

三、Access里如何实现空值替换,类似于oracle中的nvl函数

IIf(expr, truepart, falsepart)

用这个函数

IIf(a.field1='','0',a.field)

四、操作符:

Oracle             Access

as 可省略          不可省略

||                     +   &            

五、在C#中写sql语句:

1、in 操作符

Oracle: "   and dl in(" + dlList + ")   " +

Access: "   and dl in ('" +dlList + "')   " +

六、参数

2.1、参数顺序:

updCMD.CommandText = "update data setstatus = @status where [name] = @name";   

  updCMD.Connection = aConnection;

  OleDbParameter parname = new OleDbParameter("@name",OleDbType.VarChar, 50, "name");

  OleDbParameter parstatus = new OleDbParameter("@status",OleDbType.VarChar, 50, "status");

==

顺序错了, access不认参数的名字,只认参数的顺序

C# RightCode

updCMD.CommandText = " update data set status = @status where [name]= @name " ; 

updCMD.Connection = aConnection;

OleDbParameter parstatus = new OleDbParameter( " @status " , OleDbType.VarChar, 50 , " status" );

OleDbParameter parname = new OleDbParameter( " @name " , OleDbType.VarChar, 50 , " name " );

七、杂项

在做公司一个产品中,需要有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 WHERERegDate=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,kkFrom b)

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

  Insert Into a(ii,jj,kk) Select ii,jj,kkFrom 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-0111: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型(SQLServer中);