1818IP-服务器技术教程,云服务器评测推荐,服务器系统排错处理,环境搭建,攻击防护等

当前位置:首页 - 数据库 - 正文

君子好学,自强不息!

求解答啊,在数据访问由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.创建返回的表记录的类型

createorreplacetypeYourRowTypeisobject(Field1RAW(16));

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

createorrelplacetypeYourTableTypeastableofYourRowType;

3.创建函数

createorreplacefunctionYourFunction(Parameter1inRAW) 

returnYourTableType 

asreturnValueYourTableType; 

Variable1RAW(16); 

begin

  {FunctionBodyPartion} 

returnreturnValue; 

end;

4.表值函数的查询

select*fromtable(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的形式。

本文来源:1818IP

本文地址:https://www.1818ip.com/post/4415.html

免责声明:本文由用户上传,如有侵权请联系删除!

发表评论

必填

选填

选填

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。