网上有关Oracle与SQL SERVER性能差异的文章很多,结论往往是让你根据数据量与预算来选择数据库。但实际项目中,特别是使用 .Net 开发的系统,支持以上两种数据库或者更多已经成为Boss的普遍需求。

下面将常见的Oracle与SQL SERVER编程差异罗列,并提出解决方案。

1、时间格式的差异

SQL SERVER与Oracle的对时间格式的要求是不同的,SQL SERVER可以直接插入符合条件的字符串作为时间,而Oracle需要经过额外的转换。

SQL SERVER: 创建一张Test表,其中dateTime字段为datetime类型,使用以下语法是可以成功插入数据库的。

insert into test (dateTime) values('2013-10-16 20:34:38')

Oracle: 在相同环境下,执行上述语句会提示“文字与格式字符串不匹配”的错误,我们需要使用to_date将格式转换为Oracle的日期型,修改后sql语句如下。

insert into test (dateTime) values(to_date('2013-10-16 20:34:38','yyyy-mm-dd hh24:mi:ss'))

为了解决时间格式的差异,我们可以通过记录数据库类型来对sql语句进行特殊处理,这一方法可以解决后面的其它差异,在没有其它选择时是一把万能钥匙。

我们换一种思路,在此我们只是需要记录下时间,因此我们可以使用其它格式的数据来记录。比如,使用Unix时间戳。

下面是C#实现Unix时间戳与普通时间间转换的代码:

         /// <summary>
/// Converted Unix timestamp to DateTime time
/// </summary>
/// <param name="argTimeStamp">Unix timestamp</param>
/// <returns>DateTime</returns>
public DateTime GetTime(string argTimeStamp)
{
DateTime dtStart = TimeZone.CurrentTimeZone.ToLocalTime(new DateTime(, , ));
long lTime = long.Parse(argTimeStamp + "");
TimeSpan toNow = new TimeSpan(lTime);
return dtStart.Add(toNow);
} /// <summary>
/// Converted DateTime time to Unix timestamp
/// </summary>
/// <param name="argTime">DateTime</param>
/// <returns>Unix timestamp</returns>
public string ConvertDateTimeInt(DateTime argTime)
{
System.DateTime startTime = TimeZone.CurrentTimeZone.ToLocalTime(new System.DateTime(, , ));
return (argTime - startTime).TotalSeconds.ToString();
}

  现在,我们可以很方便的使用10位字符型来存储日期类型的数据了。

2、Count函数返回值的差异

在数据库操作中使用 Count 来判断是否存在是很常见的做法,Oracle 与 SQL SERVER 使用 Count 返回的类型不一致,需要通过 Convert.ToInt32 转换查询到的结果。产生这一现象的原因是 SQL SERVER 中的 int 类型在 Oracle 中为 Integer ,因此在涉及整型时将结果使用 Convert.ToInt32 转换。

SQL SERVER 与 Oracle 的类型不匹配还可能发生在使用枚举作为字段时,Oracle会将枚举解释成字符串类型,因此也需要额外的转换。

3、Convert函数的差异

在 SQL SERVER 与 Oracle 使用 Convert 的语法有明显差异。

Ø 将字符型装换为日期型

SQL SERVER:  CONVERT(DATETIME,'20131016',121)

Oracle:  to_date('2013-10-16','yyyy-mm-dd')

Ø 将日期型转换为字符型

SQL SERVER:  CONVERT(CHAR(10),GETDATE(),121)

Oracle:  to_char(sysdate,'yyyy-mm-dd')

4、别名的使用差异

在 SQL SERVER 中可以使用 as 来定义表的别名,Oracle 不支持此用法,在使用别名时需要去掉 as。Oracle 也不支持 SQL SERVER 表使用 dbo.Table 的语法。另外 SQL 语句结尾的 ‘;’ 在Oracle也不被支持。

另一个要注意的是在 Oracle 中如果有使用 union 连接时,Order by 中的列名不能加表的别名,否则会出错。

5、字符串拼接差异

在 SQL SERVER 中可以使用 ‘+’ 来拼接字符串,在 Oracle 中 ‘+’ 仅能数值型字段,字符型可以使用 “||” 或者 concat 函数来实现拼接。

本文SQL语句在 SQL SERVER 2008 和 Oracle 11g 下测试,不保证其它环境下的正确性。

本文来自 NewIdea 的博客,作者 Carey Tzou 。

原文地址:http://www.cnblogs.com/NewIdea/p/sqlbase.html

转载请注明出处,否则拒绝转载!

Oracle与SQL SERVER编程差异分析(入门)的更多相关文章

  1. ORACLE和SQL SERVER的数据同步常用方法

    ORACLE和SQL SERVER的数据同步常用方法 1. 自己编程,或者第三方工具2. 在sqlserver中,使用linkedserver,访问oracle,然后编写job进行数据同步3. 在or ...

  2. 对Oracle 、SQL Server、MySQL、PostgreSQL数据库优缺点分析

    对Oracle .SQL Server.MySQL.PostgreSQL数据库优缺点分析 Oracle Database Oracle Database,又名Oracle RDBMS,或简称Oracl ...

  3. MySQL、Oracle和SQL Server的分页查询语句

    假设当前是第PageNo页,每页有PageSize条记录,现在分别用Mysql.Oracle和SQL Server分页查询student表. 1.Mysql的分页查询: SELECT * FROM s ...

  4. Datatypes translation between Oracle and SQL Server

    Datatypes translation between Oracle and SQL Server part 1: character, binary strings Datatypes tran ...

  5. [Oracle][ODBC SQL Server Driver][SQL Server]对象名 'RECOVER.HS_TRANSACTION_LOG' 无效(转)

    原帖由 qingyun 于 2010-6-21 15:44 发表 在写pl/sql的时候,有个很重要的注意点:比如:begin  update  某个sqlserver的表@dblink名字 .... ...

  6. Oracle与SQL Server事务处理的比较

    事务处理是所有大型数据库产品的一个关键问题,各数据库厂商都在这个方面花费了很大精力,不同的事务处理方式会导致数据库性能和功能上的巨大差异.事务处理也是数据库管理员与数据库应用程序开发人员必须深刻理解的 ...

  7. InstallShield高级应用--检查是否安装ORACLE或SQL Server

    InstallShield高级应用--检查是否安装ORACLE或SQL Server   实现原理:判断是否存在,是通过查找注册表是否含有相应标识来判断的. 注意:XP与WIN7系统注册表保存方式不一 ...

  8. SQL Server审计功能入门:SQL Server审核 (SQL Server Audit)

    原文:SQL Server审计功能入门:SQL Server审核 (SQL Server Audit) 介绍 Audit是SQL Server 2008之后才有的功能,它能告诉你"谁什么时候 ...

  9. SQL Server审计功能入门:更改跟踪(Change Tracking)

    原文:SQL Server审计功能入门:更改跟踪(Change Tracking) 介绍 更改跟踪是一种轻量型解决方案,它为应用程序提供了一种有效的更改跟踪机制.常规的,自定义变更跟踪和读取跟踪数据, ...

随机推荐

  1. IOS开发UI基础UITableView的属性

    UITableView UITableView内置了两种样式:UITableViewStylePlain,UITableViewStyleGrouped <UITableViewDataSour ...

  2. Scrum 项目1.0 2.0 3.0 4.0 5.0 6.0 7.0

    1.确定选题. 应用NABCD模型,分析你们初步选定的项目,充分说明你们选题的理由. 录制为演说视频,上传到视频网站,并把链接发到团队博客上. 截止日期:2016.5.6日晚10点 阅读教材第8章,8 ...

  3. 用Qt写软件系列三:一个简单的系统工具(上)

    导言 继上篇<用Qt写软件系列二:QIECookieViewer>之后,有一段时间没有更新博客了.这次要写的是一个简单的系统工具,需求来自一个内部项目.功能其实很简单,就是查看当前当前系统 ...

  4. [CLR via C#]13. 接口

    一.类和接口继承 在Microsoft.Net Framwork中,有一个名为System.Object的类,它定义了4个公共实例方法:ToString, Equals, GetHashCode和Ge ...

  5. 使用PreparedStatement执行SQL语句时占位符(?)的用法

    1.Student数据库表 ID  name gender       2.Java代码 public static void main(String[] args) { int _id=1; Str ...

  6. mysql root强密码的必要性max_allowed_packet被改成1024引起的风险

    前两天运维反馈说,有些机器的max_allowed_packet隔两天就会被改成1024,导致客户端调用时出错,网上有说内存不够的,也有人工修改的. 运维小姑娘一口咬定肯定没有改过的,而且my.cnf ...

  7. IOS网络编请求响应之URL结构

    资料均来自互联网,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任. 人魔七七:http://www.cnblogs.com/qiqibo/ 对于我们IOS开发者来说 ...

  8. datepicker冲突

    公司里的项目由于发展较快,很多东西都没有好好梳理一下,以至于有很多的潜在的问题. 最近就遇到了一个比较坑的问题.datepicker 有两个插件库中的datepicker插件比较有名.一个是jQuer ...

  9. swift学习笔记之-下标脚本

    //下标脚本subscript import UIKit /*下标脚本(Subscripts) 下标脚本: 1.可以定义在类(Class).结构体(structure)和枚举(enumeration) ...

  10. RHEL7软件包管理

    本文介绍RHEL7的软件包管理 RHEL7下主要有RPM和YUM这两种包管理: YUM使用简单但需要联网,YUM会去网上的YUM包源去获取所需要的软件包并获取该包依赖的其他包 RPM的需要的操作精度比 ...