数据访问由SQL Server迁移向Oracle数据库的问题整理
创始人
2024-07-23 12:50:26
0

求解答啊,在数据访问由SQL Server迁移向Oracle数据库时,总会或多或少有些问题,这里,笔者把一些问题总结出来,希望高手们来帮忙解答。

一、在Oracle查询出来的字段名均为大写。

即时在SQL中使用Pascal形式写语句SELECT FieldName From TableName,返回的结果中字段名仍然为“FILEDNAME”。现解决方法为使用字段别名,语句SELECT FieldName ""FieldName"" From TableName。Oracle数据库中应该有对此进行控制的开关语句吧,求Oracle高手赐教。

二、Oracle数据库中没有Guid(UniqueIdentifier)类型。

可以在Oracle中使用RAW和CHAR类型替代GUID,但因为CHAR使用的长度过长会导致索引分页太多影响查询效率。所以尽量使用RAW(16),但注意一点,在.NET Framework中使用Guid的构造函数Guid(Byte[] byteArray)创建出来的Guid的字符串与ByteArray对应的16进制序列会有不同,比较时类型不一致会出现问题。

三、Guid类型的SQL命令参数请使用DbType.RAW,长度16,原因见上。

四、Oracle中没有现成的Table-Valued Function,需要三步创建,而且在查询中稍有不同。

1.创建返回的表记录的类型

  1. create or replace type YourRowType is object (Field1 RAW(16)); 

2.创建用表记录组成的表的类型

  1. create or relplace type YourTableType as table of YourRowType; 

3.创建函数

  1. create or replace function YourFunction (Parameter1 in RAW)  
  2.  
  3. return YourTableType  
  4.  
  5. as returnValue YourTableType;  
  6.  
  7. Variable1 RAW(16);  
  8.  
  9. begin 
  10.  
  11.   {Function Body Partion}  
  12.  
  13. return returnValue;  
  14.  
  15. end; 

4.表值函数的查询

  1. select * from table(YourFunction(parameterVariable)); 

五、基本查询语句中T-SQL与PL/SQL的异同。

1.T-SQL参数标识符为“@”,而PL/SQL中为“:”。

2.PL/SQL中无法使用“WITH(NOLOCK)”关键字,应该是用事务级别进行控制。

3.T-SQL中使用SELECT @VariableName=Count(*) FROM TableName即可向变量中写入查询值,而PL/SQL中需要SELECT COUNT(*) INTO v_variable FROM TableName的形式。

原文链接:http://www.cnblogs.com/richardc2k/archive/2011/03/18/1987971.html

【编辑推荐】

  1. SQL Server 2008中的代码安全
  2. SQL Server 2011中基于列的存储方式
  3. MongoDB1.8发布,分布式文档数据库
  4. 困扰中小型企业数据精简部署的六大问题

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
各种千兆交换机的数据接口类型详... 千兆交换机有很多值得学习的地方,这里我们主要介绍各种千兆交换机的数据接口类型,作为局域网的主要连接设...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
规避非法攻击 用好路由器远程管... 单位在市区不同位置设立了科技服务点,每一个服务点的员工都通过宽带路由器进行共享上网,和单位网络保持联...
范例解读VB.NET获取环境变... VB.NET编程语言的使用范围非常广泛,可以帮助开发人员处理各种程序中的需求,而且还能对移动设备进行...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...