Access、SQLServer、Oracle常见SQL语句应用区别
	
    
    
	
Access、SQLServer、Oracle常见SQL语句应用区别
关劲松 PMP
如果要兼容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,CAST
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这样的语句有兼容性问题,
    
     
	
	
    
    
	相关文档:
        
    
    1.多where,少having 
where用来过滤行,having用来过滤组 
2.多union all,少union 
union删除了重复的行,因此花费了一些时间 
3.多Exists,少in 
Exists只检查存在性,性能比in强很多,有些朋友不会用Exists,就举个例子 
例,想要得到有电话号码的人的基本信息,table2有冗余信息 
select * from table1;--(id,n ......
	
    
        
    
    放在这里备忘,老是忘记怎么写。
mysql> create database book;
mysql> use book;
Database changed
mysql> create table email_message(key_mail_messages INTEGER,
    -> date_created VARCHAR(19),
    -> date_updated varchar(19),
    -> date_email varchar(19),
    -> addr_from  va ......
	
    
        
    
    
1、从表中随机取记录
    select * from (select * from staff order by dbms_random.random)
    where rownum < 4
    表示从STAFF表中随机取3条记录
2、产生随机数
        SELECT DBMS_RANDOM.RANDOM from DUAL;
     ......
	
    
        
    
    
重装操作系统后,如果数据文件,控制文件,日志文件都完好的话(在itpub看过很多人提过这个话题,多数人都是将这3个文件放在同一目录oradata),只需重新安装oracle(跟重装操作系统前同版本)到原目录后,重建实例服务和密码文件,配置一下listener和tns即可正常启动数据库.
过程如下(假设原实例名为orcl,版本为9i):
1.将原来的or ......