求解答啊,在数据访问由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.创建返回的表记录的类型
- create or replace type YourRowType is object (Field1 RAW(16));
2.创建用表记录组成的表的类型
- create or relplace type YourTableType as table of YourRowType;
3.创建函数
- create or replace function YourFunction (Parameter1 in RAW)
- return YourTableType
- as returnValue YourTableType;
- Variable1 RAW(16);
- begin
- {Function Body Partion}
- return returnValue;
- end;
4.表值函数的查询
- 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
【编辑推荐】
网站名称:数据访问由SQLServer迁移向Oracle数据库的问题整理
链接分享:http://www.shufengxianlan.com/qtweb/news40/473390.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联