从Oracle迁移到SQL Server的陷阱

在把Oracle查询转换为SQL Server的时候要特别当心一些不容易注意到的问题。我们知道,T-SQL是SQL Server的语言引擎,而Oracle的语言引擎却是PLSQL。这两种查询语言都对ANSI SQL-92标准进行了扩展以提供额外的支持力度。你所创建的应用程序几乎都要用到这些补充特性。
 
   
   
   
 
 
   
   
     
       
         
       
     
     
   
 
 
   
   
   
 
本文就对最常用的、非标准的Oracle扩展进行了说明,同时还要介绍下如何对这些扩展进行转化以用在SQL Server环境下。    列的选择

  用PLSQL执行数据查询的时候,FROM子句是必须的,这同SQL Server的要求是一样的。 SELECT语句必须选择针对的数据表。在Oracle数据库内有一种特殊的表DUAL。DUAL表由Oracle连同数据字典一同创建,所有的用户都可以用名称DUAL访问该表。这个表里只有一列DUMMY,该列定义为VARCHAR2(1)类型,有一行值X。

  从DUAL表选择数据常被用来通过SELECT语句计算常数表达式,由于DUAL只有一行数据,所以常数只返回一次。

  Oracle下的DUAL查询如下所示:
    SELECT ‘x’ FROM dual 
  而对等的SQL Server查询则是下面这个样子:
  SELECT ‘x’ 
  连接

  Oracle用|| 符号作为连接符,而SQL Server的连接符是加号:  。

  Oracle查询如下所示:
  Select ‘Name’ || ‘Last Name’ From tableName 
  对应的SQL Server查询如下所示:
  Select ‘Name’  ‘Last Name’

 感谢原创者的辛勤劳动,希望对您有所帮助,转载请注明原出处。
 您可能对 [SQL Server] 的这些文章也感兴趣:

SQL Server 2005关于数据类型最大值
在Linux下访问MS SQL Server数据库
解析SQL Server 2008中的新语句:MERGE
SQL Server 2005中的SQLCMD工具使用
SQL Server中单引号的两种处理技巧
如何在SQL Server中使用CLR调用.NET方法
SQL Server SQL语句导入导出大全
SQLServer身份验证管理子程序
SQLServer和Access、Excel数据传输简单总结
SQL Server:安全设计从头起