原作者:关劲松 PMP
来源:http://hi.baidu.com/okhymok/blog/item/c99132667ac5c258eaf8f8aa.html
搜集整理:sagahu@163.com 日期:2011-10-14 15:31
为了兼容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这样的语句有兼容性问题。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述