Oracle与SQL SERVER编程差异分析(入门)
网上有关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编程差异分析(入门)的更多相关文章
- ORACLE和SQL SERVER的数据同步常用方法
ORACLE和SQL SERVER的数据同步常用方法 1. 自己编程,或者第三方工具2. 在sqlserver中,使用linkedserver,访问oracle,然后编写job进行数据同步3. 在or ...
- 对Oracle 、SQL Server、MySQL、PostgreSQL数据库优缺点分析
对Oracle .SQL Server.MySQL.PostgreSQL数据库优缺点分析 Oracle Database Oracle Database,又名Oracle RDBMS,或简称Oracl ...
- MySQL、Oracle和SQL Server的分页查询语句
假设当前是第PageNo页,每页有PageSize条记录,现在分别用Mysql.Oracle和SQL Server分页查询student表. 1.Mysql的分页查询: SELECT * FROM s ...
- Datatypes translation between Oracle and SQL Server
Datatypes translation between Oracle and SQL Server part 1: character, binary strings Datatypes tran ...
- [Oracle][ODBC SQL Server Driver][SQL Server]对象名 'RECOVER.HS_TRANSACTION_LOG' 无效(转)
原帖由 qingyun 于 2010-6-21 15:44 发表 在写pl/sql的时候,有个很重要的注意点:比如:begin update 某个sqlserver的表@dblink名字 .... ...
- Oracle与SQL Server事务处理的比较
事务处理是所有大型数据库产品的一个关键问题,各数据库厂商都在这个方面花费了很大精力,不同的事务处理方式会导致数据库性能和功能上的巨大差异.事务处理也是数据库管理员与数据库应用程序开发人员必须深刻理解的 ...
- InstallShield高级应用--检查是否安装ORACLE或SQL Server
InstallShield高级应用--检查是否安装ORACLE或SQL Server 实现原理:判断是否存在,是通过查找注册表是否含有相应标识来判断的. 注意:XP与WIN7系统注册表保存方式不一 ...
- SQL Server审计功能入门:SQL Server审核 (SQL Server Audit)
原文:SQL Server审计功能入门:SQL Server审核 (SQL Server Audit) 介绍 Audit是SQL Server 2008之后才有的功能,它能告诉你"谁什么时候 ...
- SQL Server审计功能入门:更改跟踪(Change Tracking)
原文:SQL Server审计功能入门:更改跟踪(Change Tracking) 介绍 更改跟踪是一种轻量型解决方案,它为应用程序提供了一种有效的更改跟踪机制.常规的,自定义变更跟踪和读取跟踪数据, ...
随机推荐
- CentOS6.5菜鸟之旅:纯转载Linux目录结构
来自:http://www.iteye.com/topic/1125162 使用linux也有一年多时间了 最近也是一直在维护网站系统主机 下面是linux目录结构说明 本人使用的是centos系 ...
- STL --- UVA 123 Searching Quickly
UVA - 123 Searching Quickly Problem's Link: http://acm.hust.edu.cn/vjudge/problem/viewProblem.acti ...
- 【WP8】扩展CM的WindowManager
14-09-09更新:修复AppBar冲突bug 关于WindowManager,一直都很想写一篇博客分享一下,一直在忙别的,今天抽空把这个分享一下 在弹窗在移动开发是一个很常见的交互,很多时候我们都 ...
- sql添加合计
在项目中发现有这样的写法 SELECT ZoneID,CountSQAZFZSBJZ3G+CountSQGZJRJZSL3G AS column1FROM G3MulticarrierSiteCove ...
- 从零开始学习Linux(ls命令)
学习Linux已经两年了,可是仍然是小白一个.用过很多命令,可是很多都没记住,基础不扎实,很大程度上是不记笔记,得过且过. 从今天起,开始整理Linux笔记. Linux每个命令都有--help这个选 ...
- java ftp
FTPUtil import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import jav ...
- Java中处理异常中return关键字
Java中,执行try-catch-finally语句需要注意: 第一:return语句并不是函数的最终出口,如果有finally语句,这在return之后还会执行finally(return的值会暂 ...
- ahjesus不断完善的js小"内裤"
String.prototype.isNullOrWhiteSpace = function () { /// <summary> /// 变量是undefined或者null或者空字符串 ...
- Angularjs,WebAPI 搭建一个简易权限管理系统 —— Angularjs名词与概念(一)
目录 前言 Angularjs名词与概念 Angularjs 基本功能演示 系统业务与实现 WebAPI项目主体结构 Angularjs 前端主体结构 2. 前言 Angularjs开发CRUD类型的 ...
- css设置height 100%
需要显式设置html,body为100%,body是相对于html,wrapper是相对于body html,body{ height: 100%; } .wrapper{ height: 100; ...