`
linhui_dragon
  • 浏览: 156162 次
  • 性别: 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等数据库中使用,我上传的文件有相关的例子,很容易看懂。

    oracle-instantclient(64bits)_win

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

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

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

    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 ...

    《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