Форум программистов, компьютерный форум, киберфорум
C#: Базы данных, ADO.NET
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 26.05.2015
Сообщений: 1
1

Ошибка при Update, значение параметра вне допустимого диапазона

26.05.2015, 21:13. Показов 1076. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Есть простая форма, на которой:
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
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
26.05.2015, 21:13
Ответы с готовыми решениями:

"Вне допустимого диапазона" на втором мониторе
Доброго времени суток! Подключил к ноутбуку монитор и сделал его основным (сам хз зачем, играл с...

Ошибка: Аргументы имеют неверный тип, выходят за пределы допустимого диапазона
Не могу решить проблему связки таблиц. Ошибка: Аргументы имеют неверный тип, выходят за пределы...

При поиске последней строки возникает ошибка, что ячейка вне диапазона
всем привет, столкнулся с проблемой. На листе всего 12 записей, необходимо найти последнюю строку...

Ошибка: Аргументы имеют неверный тип, выходят за пределы допустимого диапазона или вступают в конфликт
Уважаемые программисты прошу вас помогите мне пожалуйста.Я создаю программу в Delphi которая...

0
26.05.2015, 21:13
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
26.05.2015, 21:13
Помогаю со студенческими работами здесь

AddNew приводит к ошибке Ошибка 800a0bb9 Аргументы имеют неверный тип, выходят за пределы допустимого диапазона ..
Вопрос возможно уже всем тут надоел, но я ничего подобного поиском не нашел... Нужен AddNew. Делаю...

При вводе данных в программу возникает ошибка "индекс вне диапазона"
При вводе данных в программу вылетает ошибка "индекс вне диапазона".Помогите исправить пожалуйста....

Ошибка "Вне диапазона" при ручном изменении настроек в Heroes of the Storm
У меня старый монитор разрешением 1024х768 где здесь изменить его что бы не было ошоибки? ...

Ошибка: "Аргументы имеют неверный тип, выходят за пределы допустимого диапазона или вступают в конфликт"
Мне нужно отсортировать несколько столбцов по клику на заголовке столбца в dbgrid, есть столбцы с...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru