2

算術オーバーフロー エラーを示すこのクエリで問題が発生しています。

INSERT INTO seed_health_testing_form (seedlotno, modeoftesting, datetested, 
    datecollected, placecollected, sampleno, germination1, germination2, 
    germination3, germination4, germination5, germination6, germination7, 
    germination8, germination9, germination10, remarks) 
VALUES ( 'A00075', 'GTest', '2/14/2013', 
    '2/19/2013', 'Laguna', 0, 50.00, 50.00, 
    50.00, 50.00, 0.00, 0.00, 0.00, 
    0.00, 0.00, 0.00, '')

テーブルデザイン

[id]                [int]       IDENTITY(1,1) PRIMARY KEY NOT NULL
[seedlotno]         [varchar](50)   NULL
[modeoftesting]     [varchar](100)  NULL
[datetested]        [datetime]      NULL
[datecollected]     [datetime]      NULL
[placecollected]    [varchar](100)  NULL
[sampleno]          [int]           NULL
[germination1]      [decimal](3, 2) NULL
[germination2]      [decimal](3, 2) NULL
[germination3]      [decimal](3, 2) NULL
[germination4]      [decimal](3, 2) NULL
[germination5]      [decimal](3, 2) NULL
[germination6]      [decimal](3, 2) NULL
[germination7]      [decimal](3, 2) NULL
[germination8]      [decimal](3, 2) NULL
[germination9]      [decimal](3, 2) NULL
[germination10]     [decimal](3, 2) NULL
[remarks]           [varchar](1000) NULL

INSERT クエリを 1 行ずつ分割してエラーの場所を追跡しようとしましたが、常に 1 行目を指しています。それでも、問題がどこにあるのかわかりません。

4

1 に答える 1

7

すべての[decimal](3, 2)データ型が問題です。

(3,2)、数値の精度が合計3桁で、小数点以下2桁が予約されていることを示しています。

50したがって、オーバーフローの原因となる、のような値を格納するために使用できるのは1桁だけです。

詳細については、decmialデータ型のドキュメントを参照してください。

于 2013-02-26T17:53:19.300 に答える