Ошибка при Update, значение параметра вне допустимого диапазона
26.05.2015, 21:13. Показов 1076. Ответов 0
Есть простая форма, на которой:
GridView, пара листбоксов.
Хранимка в SqlServer на вставку/апдейт данных.
На некоторых записях попытка сохранить данные падает с эксепшеном и сообщением "значение параметра \"...\" вне допустимого диапазона."
вместо ... указан идентификатор записи.
падение происходит при вызове ApplyChanges, чтобы было понятно о чем речь - немного больше кода:
C# | 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
| protected void initAdapter()
{
Connection = new SqlConnection(SynonymsVS.Common.Utilities.ConnectionString);
cmdSynonymsSelect = new SqlCommand("select * from dbo.Synonyms Where IsActive = 1 and CircleId = @CircleId and IsEthalon = @IsEthalon", Connection);
cmdSynonymsSelect.Parameters.Add(new System.Data.SqlClient.SqlParameter("@CircleId", System.Data.SqlDbType.Decimal, 18));
cmdSynonymsSelect.Parameters.Add(new System.Data.SqlClient.SqlParameter("@IsEthalon", System.Data.SqlDbType.Bit));
cmdSynonymsPut = new SqlCommand("dbo.Synonym_Put", Connection);
cmdSynonymsPut.CommandType = CommandType.StoredProcedure;
cmdSynonymsPut.Parameters.Add(new System.Data.SqlClient.SqlParameter("@Id", System.Data.SqlDbType.Decimal, 18, "SynonymId"));
cmdSynonymsPut.Parameters["@Id"].Direction = ParameterDirection.InputOutput;
cmdSynonymsPut.Parameters.Add(new System.Data.SqlClient.SqlParameter("@Text", System.Data.SqlDbType.VarChar, 255, "SynonymText"));
cmdSynonymsPut.Parameters.Add(new System.Data.SqlClient.SqlParameter("@CircleId", System.Data.SqlDbType.Decimal, 18, "CircleId"));
cmdSynonymsPut.Parameters.Add(new System.Data.SqlClient.SqlParameter("@Comment", System.Data.SqlDbType.VarChar, 100, "Comment"));
cmdSynonymsPut.Parameters.Add(new System.Data.SqlClient.SqlParameter("@Source", System.Data.SqlDbType.VarChar, 100, "Source"));
cmdSynonymsPut.Parameters.Add(new System.Data.SqlClient.SqlParameter("@IsEthalon", System.Data.SqlDbType.Bit, 1, "IsEthalon"));
cmdSynonymsDel = new SqlCommand("dbo.Synonym_Del", Connection);
cmdSynonymsDel.CommandType = CommandType.StoredProcedure;
cmdSynonymsDel.Parameters.Add(new System.Data.SqlClient.SqlParameter("@Id", System.Data.SqlDbType.Decimal, 18, "SynonymId"));
daSynonyms = new SqlDataAdapter();
daSynonyms.SelectCommand = cmdSynonymsSelect;
daSynonyms.InsertCommand = cmdSynonymsPut;
daSynonyms.UpdateCommand = cmdSynonymsPut;
daSynonyms.DeleteCommand = cmdSynonymsDel;
}
public void ApplyChanges()
{
try
{
daSynonyms.Update(this.Table);
}
catch (Exception ex)
{
MessageBox.Show("Ошибка при сохранении изменений в синонимах, данные:" + ex.Message);
}
} |
|
Серверная сторона:
SQL | 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
| CREATE TABLE [dbo].[Synonyms](
[SynonymId] [NUMERIC](18, 0) IDENTITY(1,1) NOT NULL,
[SynonymText] [nvarchar](255) NOT NULL,
[CircleId] [NUMERIC](18, 0) NOT NULL,
[IsActive] [bit] NOT NULL,
[Comment] [nvarchar](100) NULL,
[SOURCE] [nvarchar](100) NULL,
[IsEthalon] [bit] NOT NULL,
CONSTRAINT [PK_Synonyms] PRIMARY KEY CLUSTERED
(
[SynonymId] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
CREATE PROCEDURE [dbo].[Synonym_Put]
@Id NUMERIC(18,0) OUTPUT
, @Text nvarchar(255)
, @CircleId NUMERIC(18,0)
, @Comment nvarchar(100)
, @SOURCE nvarchar(100)
, @IsEthalon bit
AS
IF (@Id IS NULL)
-- insert
BEGIN
INSERT INTO dbo.Synonyms (SynonymText, CircleId, IsActive, Comment, SOURCE, IsEthalon )
VALUES (@Text, @CircleId, 1, @Comment, @SOURCE, @IsEthalon)
SELECT @Id = SCOPE_IDENTITY()
END
-- update
BEGIN
UPDATE dbo.Synonyms
SET
SynonymText = @Text,
CircleId = @CircleId,
IsActive = 1,
Comment = @Comment,
SOURCE = @SOURCE,
IsEthalon = @IsEthalon
WHERE SynonymId = @Id
END
GO |
|
Добавлено через 2 минуты
Еще раз отдельно замечу: падает код только на некоторых записях.
В отладке проверил что происходит в Update построчно, смотрел на параметры, значение у ID верное, тип тоже. Чем может быть вызвана ошибка?
При необходимости могу предоставить полные исходники.
Добавлено через 10 минут
Кратко суть проблемы с формой:
Выбираем некоторое поле через гридвью, редактируем, пытаемся сохранить. Получаем в итоге ошибку.
0
|