本文整理汇总了C#中OracleDataReader.GetInternalDataTypes方法的典型用法代码示例。如果您正苦于以下问题:C# OracleDataReader.GetInternalDataTypes方法的具体用法?C# OracleDataReader.GetInternalDataTypes怎么用?C# OracleDataReader.GetInternalDataTypes使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类OracleDataReader
的用法示例。
在下文中一共展示了OracleDataReader.GetInternalDataTypes方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: FetchRecordsFromReader
internal static IEnumerable<object[]> FetchRecordsFromReader(OracleDataReader reader, int rowCount, bool prefetch)
{
if (!CanFetchFromReader(reader))
{
yield break;
}
var fieldTypes = new string[reader.FieldCount];
var internalTypes = reader.GetInternalDataTypes();
for (var i = 0; i < reader.FieldCount; i++)
{
var fieldType = reader.GetDataTypeName(i);
fieldTypes[i] = internalTypes[i] == OracleRowId.InternalCode ? OracleRowId.TypeName : fieldType;
}
for (var i = 0; i < rowCount; i++)
{
if (!CanFetchFromReader(reader))
{
yield break;
}
object[] values;
try
{
if (reader.Read())
{
values = BuildValueArray(reader, fieldTypes, prefetch);
}
else
{
reader.Close();
yield break;
}
}
catch
{
if (!reader.IsClosed)
{
reader.Close();
}
throw;
}
yield return values;
}
}