`
linhui_dragon
  • 浏览: 157419 次
  • 性别: Icon_minigender_2
  • 来自: 北京
社区版块
存档分类
最新评论

ORACLE -- SQL Server -- Access 常见Sql语句的区别

 
阅读更多

AccessSQLServerOracle常见SQL语句应用区别
关劲松 PMP
如果要兼容AccessSQL ServerOracle三个数据库版本;我们在编写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
UCaseLCaseInStr
S:SubString
UpperLowerCharIndex
O:SubStr
UpperLowerInStr
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 ServerOracle中都不会有错
  
8
、关键字
  有些字母在Access,SQL Server中是关键字,需要用[ ]界定可解决问题,例如:at,name
  
9
、别名
  SQL ServerOracle中字段起别名时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中的逻辑值在库中为-10,SQL Server中为10,所以写BoolField = 1这样的语句有兼容性问题, ......<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

分享到:
评论

相关推荐

    Oracle-PL-SQL入门教程(经典)

    - **兼容性与扩展性**:大多数主流的关系型数据库管理系统如Oracle、Sybase、Microsoft SQL Server、Access等均支持SQL语言标准。尽管许多数据库系统对其进行了定制化开发和功能扩展,但基本的SQL命令如SELECT、...

    sql语句命令-sql语句命令sql语句命令

    总结来说,SQL语句命令在数据库操作中扮演着核心角色,而ADO.NET提供了SqlConnection、SqlCommand、SqlDataAdapter等类,使得与SQL Server和其他OLE DB兼容数据库的交互变得更加便捷。理解并熟练掌握这些工具,对于...

    ORACLE、MySQL、SqlServer,三大数据库区别整理以及常用语句

    ### ORACLE、MySQL、SqlServer,三大数据库区别整理以及常用语句 #### 一、数据库简介与对比 在当今数字化时代,数据库技术对于企业信息化管理至关重要。ORACLE、MySQL与SQL Server作为市场上广受欢迎的三种数据库...

    oracle ora-各种常见java.sql.SQLException归纳

    这种错误通常是由于开发者在编写 SQL 语句时,忘记了某个分号或写错了分号,导致 Oracle 无法执行 SQL 语句。解决这个错误的方法是,检查 SQL 语句中的分号是否正确,确保 SQL 语句正确结束。 ORA-01722: 无效数字 ...

    数据库查询自定义排序,适合oracle,MySql,SqlServer,access等等

    在一次做项目的时候,项目已经做完了,...结果弄出来了,就一条sql语句就能实现,现在我把我的成果分享给大家,这自定义排序能够在oracle,MySql,SqlServer,access使用,我现在打包压缩分享给大家,希望你们能够喜欢。

    Time-Based Blind SQL Injection using heavy queries- A practical approach for MS SQL Server, MS Access, Oracle and MySQL databases and Marathon Tool

    这种攻击方式在目标系统不返回具体错误信息或者数据时特别有效,适用于MS SQL Server、MS Access、Oracle和MySQL等常见数据库系统。本文将深入探讨时间基盲注的概念、原理及其在实际环境中的应用,同时也会介绍...

    SQL基础_-_MS-SQL_Server___基础类

    - **服务器级数据库**:如Oracle、DB2、SQL Server、MySQL、PostgreSQL等,适用于大型企业级应用,需要专门的数据库服务器。 ##### 3.2 服务器(Server)与客户端(Client) - **服务器(Server)**:负责维护数据库,并...

    mysql_sqlserver_oracle-jdbc.rar

    标题中的"mysql_sqlserver_oracle-jdbc.rar"表明这是一个压缩包,包含了与MySQL、SQL Server和Oracle数据库相关的JDBC驱动程序。JDBC(Java Database Connectivity)是Java编程语言用来规范应用程序如何访问数据库的...

    自定义查询排序,适合于oracle,mySql,SqlServer,access等数据库

    在一次项目中,项目已经就快完了,需求有来了,要求要按指定的方式排序,通过id,时间等进行正排序,倒排序 ...,适合于oracle,mySql,SqlServer,access等数据库中使用,我上传的文件有相关的例子,很容易看懂。

    Access、SQLServer、Oracle三种数据库的区别.pdf

    Access、SQL Server、Oracle是三种不同的关系型数据库管理系统(RDBMS),它们在功能、性能、安全性、适用场景等方面有着显著的区别。 1. **取当前系统时间** - Access: 使用 `Now()` 函数获取当前日期和时间。 -...

    oracle-instantclient(64bits)_win

    2. **sqlplus.exe**: SQL*Plus,一个命令行工具,允许用户输入SQL语句、PL/SQL块以及执行数据库管理任务。 3. **tnsnames.ora**: TNS(Transparent Network Substrate)命名服务配置文件,定义了数据库连接的逻辑...

    sqlserver2008链接ORACLE服务器驱动.rar

    6. **测试连接**:完成配置后,可以使用T-SQL语句(如`EXEC sp_addlinkedserver`)来测试与Oracle的连接。 7. **数据迁移或查询**:一旦连接成功,你就可以使用SQL Server Management Studio(SSMS)进行跨数据库...

    创建链接服务器(oracle,sql server,access,excel)

    通过创建链接服务器,你可以执行跨服务器的Transact-SQL语句,就像这些服务器上的表和视图是本地资源一样。 对于Oracle数据库,SQL Server提供了一个名为"Oracle Provider for OLE DB"的驱动程序来建立连接。配置...

    ado.net操作oracle简单参数化sql操作

    参数化查询是通过使用参数占位符而不是直接将值插入SQL语句来实现的,这有助于防止SQL注入。在ADO.NET中,我们使用OracleCommand对象来执行SQL命令,并通过OracleParameter对象来定义参数。假设我们有一个查询,需要...

    SQL语句大全(mysql,sqlserver,Access,Oracle)

    SQL(Structured Query Language)是用于管理和操作关系数据库的语言,它被广泛应用于MySQL、SQL Server、Access和Oracle等数据库管理系统中。以下是对SQL语句的主要功能的详细解释: 1. **数据操作** - **SELECT*...

    Access、SQL Server、Oracle三种数据库的区别.doc

    Access、SQL Server、Oracle是三种不同的关系型数据库管理系统(RDBMS),它们各自拥有独特的特性和功能,适用于不同规模和需求的应用场景。 1. **获取当前系统时间**: - Access(A):使用`Now()`函数。 - SQL ...

    SQL语句教程 写法大全

    同时,本教程还涵盖了 SQL 高级知识,如 Top 语句、Like 语句、通配符、In 语句、Between 语句、Aliases 语句、Join 语句、Inner Join 语句、Left Join 语句、Right Join 语句、Full Join 语句、Union 语句、Select ...

    SQL语句性能调整 ORACLE的执行计划.

    SQL 语句性能调整 ORACLE 的执行计划 SQL 语句性能调整是 Oracle 数据库开发中非常重要的一部分,它直接影响到数据库的性能和效率。在这里,我们将详细介绍 SQL 语句性能调整的原理和方法,以及 ORACLE 的执行计划...

    《Pro Oracle SQL》Chapter10 -- 10.2 Optimizing SQL -10.2.1Testing Execution Plans

    SQL执行计划是Oracle数据库为执行一个特定SQL语句所设计的步骤序列。它决定了数据的检索方式,包括表的扫描顺序、连接方法、索引的使用以及排序等操作。优化执行计划可以显著减少查询时间,从而提升应用的响应速度...

    mysql oracle sqlserver jdbc驱动包

    JDBC驱动包提供了执行SQL语句、处理结果集等功能,使得Java代码能与MySQL数据库无缝对接。 2. Oracle JDBC驱动包:`oracle.jar` Oracle数据库是全球最广泛使用的商业数据库之一,尤其在大型企业中常见。`oracle....

Global site tag (gtag.js) - Google Analytics