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;
IIf(expr, truepart, falsepart)
用这个函数
IIf(a.field1='','0',a.field)
Oracle Access
as 可省略 不可省略
|| + &
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
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 WHERERegDate=To_Date('2007-05-01','yyyy-mm-dd')
A:CStr,CInt,CDate
S:Convert
O:To_Char,To_Number,To_Date
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中都不会有错
有些字母在Access,SQL Server中是关键字,需要用[ ]界定可解决问题,例如:at,name
SQL Server和Oracle中字段起别名时as可以省略,Access不能
Select *,1 From A
这样的语句在Access,SQL Server中不会有错,但在Oracle中是不行的,必须要写成这样:
Select A.*,1 From A
例如有时间字段的查询:CalcDate=#2008-05-0111:00:00#,在Access中一般会出现如下错误:不正常地定义参数对象。提供了不一致或不完整的信息。将相应Query的ParamCheck设为False即可。
Access中的逻辑值在库中为-1和0,而SQL Server中为1和0,所以写BoolField = 1这样的语句有兼容性问题,应该改为BoolField <> 0
Access的varchar(文本)型最大只有255,所以如果一个文本型字段大于255时,最好定义成备注型(Access中)或text型(SQLServer中);