当前位置: 首页>>代码示例>>C#>>正文


C# SqlDataRecord.GetChars方法代码示例

本文整理汇总了C#中Microsoft.SqlServer.Server.SqlDataRecord.GetChars方法的典型用法代码示例。如果您正苦于以下问题:C# SqlDataRecord.GetChars方法的具体用法?C# SqlDataRecord.GetChars怎么用?C# SqlDataRecord.GetChars使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Microsoft.SqlServer.Server.SqlDataRecord的用法示例。


在下文中一共展示了SqlDataRecord.GetChars方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: SetChars_FromRecord

        private static void SetChars_FromRecord( SmiEventSink_Default sink, ITypedSettersV3 setters, int ordinal, SmiMetaData metaData, SqlDataRecord record, int offset ) {
            int length = 0;

            // Deal with large values by sending bufferLength of NoLengthLimit
            //  CheckXetParameters will ignore length checks in this case
            long bufferLength = record.GetChars(ordinal, 0, null, 0, 0);
            if ( bufferLength > Int32.MaxValue ) {
                bufferLength = NoLengthLimit;
            }
            length = CheckXetParameters( metaData.SqlDbType, metaData.MaxLength, NoLengthLimit /* actual */, 0, checked( (int) bufferLength ), offset, checked( (int) bufferLength - offset ) );

            int chunkSize;
            if ( length > __maxCharChunkSize || length < 0 ) {
                if (MetaDataUtilsSmi.IsAnsiType(metaData.SqlDbType)) {
                    chunkSize = __maxByteChunkSize;
                } else {
                    chunkSize = __maxCharChunkSize;
                }
            }
            else {
                chunkSize = checked( (int)length );
            }

            char[] buffer = new char[ chunkSize ];
            long charsRead;
            long charsWritten = 1;  // prime value to get into write loop
            long currentOffset = offset;
            long lengthWritten = 0;

            while ( (length < 0  || lengthWritten < length) &&
                    0 != ( charsRead = record.GetChars( ordinal, currentOffset, buffer, 0, chunkSize ) ) &&
                    0 != charsWritten ) {
                charsWritten = setters.SetChars( sink, ordinal, currentOffset, buffer, 0, checked( (int) charsRead ) );
                sink.ProcessMessagesAndThrow();
                checked{ currentOffset += charsWritten; }
                checked{ lengthWritten += charsWritten;}
            }

            // Make sure to trim any left-over data
            setters.SetCharsLength( sink, ordinal, currentOffset );
            sink.ProcessMessagesAndThrow();
        }
开发者ID:uQr,项目名称:referencesource,代码行数:42,代码来源:ValueUtilsSmi.cs

示例2: SetChars_FromRecord

 private static void SetChars_FromRecord(SmiEventSink_Default sink, ITypedSettersV3 setters, int ordinal, SmiMetaData metaData, SqlDataRecord record, int offset)
 {
     int num4;
     long num7;
     int num = 0;
     long num5 = record.GetChars(ordinal, 0L, null, 0, 0);
     if (num5 > 0x7fffffffL)
     {
         num5 = -1L;
     }
     num = CheckXetParameters(metaData.SqlDbType, metaData.MaxLength, -1L, 0L, (int) num5, offset, ((int) num5) - offset);
     if ((num > 0xfa0) || (num < 0))
     {
         if (MetaDataUtilsSmi.IsAnsiType(metaData.SqlDbType))
         {
             num4 = 0x1f40;
         }
         else
         {
             num4 = 0xfa0;
         }
     }
     else
     {
         num4 = num;
     }
     char[] buffer = new char[num4];
     long num3 = 1L;
     long fieldOffset = offset;
     for (long i = 0L; ((num < 0) || (i < num)) && ((0L != (num7 = record.GetChars(ordinal, fieldOffset, buffer, 0, num4))) && (0L != num3)); i += num3)
     {
         num3 = setters.SetChars(sink, ordinal, fieldOffset, buffer, 0, (int) num7);
         sink.ProcessMessagesAndThrow();
         fieldOffset += num3;
     }
     setters.SetCharsLength(sink, ordinal, fieldOffset);
     sink.ProcessMessagesAndThrow();
 }
开发者ID:pritesh-mandowara-sp,项目名称:DecompliedDotNetLibraries,代码行数:38,代码来源:ValueUtilsSmi.cs


注:本文中的Microsoft.SqlServer.Server.SqlDataRecord.GetChars方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。