15

ulongC#.NETを T-SQL データベースに格納したいと考えています。bigintSQLには通常の と同じ Min/Max 値があるため、これを行うための規定はありませんlong

これを行う方法はありますか?それとも捕まえるOverflowExceptionことが唯一の希望?

4

3 に答える 3

9

これはあなたの質問に答えるはずです:

http://social.msdn.microsoft.com/Forums/en-US/adodotnetdataproviders/thread/ff08c190-a981-4896-9542-3f64b95a84a2/

BigInt を使用しますが、C# で符号付きの型を符号なしの型に変換する方法に注意する必要があります。

// This has not been tested
unchecked
{
    myUlong = myDataReader.GetInt64(...);
}

...

もう 1 つの可能性は、長さ 8 の VarBinary を使用してから、バイトを C# の ulong に変換することです。

于 2010-06-02T14:42:10.143 に答える
6

私はそれが同じではないことを知っていますが、これはどうなりますか:

select convert(decimal(38, 0), 12345678901234567890123456789012345678)

unsigned long の最大値は 18,446,744,073,709,551,615 のようです。これは、この 10 進数が格納できる値よりも大幅に小さい値です。変換時に問題が発生する可能性がありますが、アプリケーション内のいくつかのラッパー関数を使用すると、かなり迅速に並べ替えることができると確信しています。

于 2010-06-02T14:41:58.447 に答える