|
11 / 11 / 0
Регистрация: 23.05.2009
Сообщений: 9
|
||||||||||||||||
Обновление БД11.06.2009, 18:29. Показов 18269. Ответов 18
Метки нет (Все метки)
Не могу разобраться как обновить данные в бд... Загрузка происходит следующим образом:
Нигде ничего вразумительного не нашел Помогите разобраться!
0
|
||||||||||||||||
| 11.06.2009, 18:29 | |
|
Ответы с готовыми решениями:
18
Обновление базы и ошибка: Обновление невозможно. База данных или объект доступны только для чтения. |
|
19 / 19 / 4
Регистрация: 30.04.2009
Сообщений: 142
|
|||
| 11.06.2009, 20:12 | |||
т.е. нужно добавить UpdateCommand в adapter, как мне кажется
0
|
|||
|
|
|
| 15.06.2009, 00:52 | |
|
необходимо прописать все команды : updatecommand, deletecommand, insertcommand
Если используется простой SELECT выбирающий данные только из одной таблицы, то сделать это можно автоматически при помощи CommandBuilder (если не ошибаюсь). Раньше я так делал. Сейчас использую встроенные компоненты студии (DataSet, TableAdapter), так на много быстрее (все запросы создаются автоматом), если нужно реализовать что-то не сильно сложное.
0
|
|
|
28 / 28 / 7
Регистрация: 12.06.2009
Сообщений: 71
|
||||||
| 17.06.2009, 09:48 | ||||||
|
Испробовал твой код для сохранения изменений в бд, все работает. НО использовал не OleDbDataAdapter, а sqlDataAdapter, думаю большого различия нет. Еще одна небольшая коректировка: экземпляр класса DataSet создал как public
0
|
||||||
|
|
|
| 18.06.2009, 17:58 | |
|
проблема в том, что ты открываешь соединение, создаешь экземпляр command и закрываешь соединение. А потом уже делаешь адаптер и датасет. Фактически методы Fill и Update обращаются к БД, а у тебя они пытаются это сделать после того как соединение закрыто. Так что переставь connection.Close() в конец метода и все должно заработать.
И еще. DataSet может содержать несколько таблиц, поэтому, кода выполняшь Fill и Update, также нужно указывать имя или номер таблицы, для которой ты это делаешь, иначе эти действия будут производится со всеми таблицами, что негативно сказывается на объемах трафика.
0
|
|
|
Комбайнёр
1606 / 704 / 77
Регистрация: 27.05.2008
Сообщений: 2,535
|
|
| 18.06.2009, 19:11 | |
|
Люди, пользуйтесь дизайнером для подключения и создания адаптеров, датасетов и датасоурсов (хсд схемы) или пользуйтесь LINQ и тогда у Вас не будет никаких проблем, как и что.
0
|
|
|
1923 / 428 / 41
Регистрация: 12.07.2007
Сообщений: 2,062
|
|||
| 19.06.2009, 04:19 | |||
|
Добавлено через 5 минут 5 секунд
0
|
|||
|
0 / 0 / 0
Регистрация: 15.06.2009
Сообщений: 15
|
|
| 30.06.2009, 16:44 | |
|
а если мне нужно изменить какую-то определенную строку (определяется по ключевому полю "Id") в таблице "mytable", где мне нужно это указывать? - в запросе "Select * FROM mytable where id= " & i (где i - какая-то переменная, определяющая строку), в выражении "Update ... where id= " & i или сначала надо выбрать все записи из таблицы, а потом проверять значения каждую строки DataTable.Rows.Items("Id")?
0
|
|
|
1923 / 428 / 41
Регистрация: 12.07.2007
Сообщений: 2,062
|
|
| 01.07.2009, 03:05 | |
|
Нужно в заполненной таблице изменить нужную строку и вызвать у адаптера Update. При этом у адаптера должен быть реализован UpdateCommand с запросом типа update (update...where...). Адаптер сам найдет измененную строку и обновит ее значение в БД на новое.
1
|
|
|
0 / 0 / 0
Регистрация: 15.06.2009
Сообщений: 15
|
|
| 01.07.2009, 11:42 | |
|
Green,
т.е. насколько я понимаю, я сначала выбираю все записи из таблицы SelectCommand= ("Select * FROM mytable",connection), заполняю таблицу из датаадаптера, потом в таблице ищу нужную запись, изменяю ее, потом добавляю к датаадаптеру UpdateCommand=(Update ... where id= " & i, connection) и делаю Update. Так?
0
|
|
|
1923 / 428 / 41
Регистрация: 12.07.2007
Сообщений: 2,062
|
|
| 02.07.2009, 02:19 | |
|
Да. Также для запросов insert и delete.
0
|
|
|
11 / 11 / 0
Регистрация: 23.05.2009
Сообщений: 9
|
||||||
| 06.07.2009, 17:43 [ТС] | ||||||
|
Я примерно разобрался...
1
|
||||||
|
1923 / 428 / 41
Регистрация: 12.07.2007
Сообщений: 2,062
|
||||||
| 07.07.2009, 05:38 | ||||||
|
кажется здесь
0
|
||||||
|
0 / 0 / 0
Регистрация: 15.06.2009
Сообщений: 15
|
|
| 09.07.2009, 23:31 | |
|
интересный код
a что это за объект d1?
0
|
|
|
1923 / 428 / 41
Регистрация: 12.07.2007
Сообщений: 2,062
|
|
| 10.07.2009, 02:54 | |
|
avers_inc, насколько я понял это DataGridView
0
|
|
|
0 / 0 / 0
Регистрация: 15.06.2009
Сообщений: 15
|
|
| 10.07.2009, 12:11 | |
|
насколько я понимаю, то этот код может обрабатывать любую таблицу, заданную переменной mytablename... только ключевым полем в этой таблице должно быть первое поле. А как сделать так чтоб в коде определить какое из полей является ключевым? тогда можно было б совсем любую таблицу подставлять
0
|
|
|
1923 / 428 / 41
Регистрация: 12.07.2007
Сообщений: 2,062
|
|
| 13.07.2009, 03:24 | |
|
Нет, не любую. На таком автомате получишь исключение, при попытке изменить поля только на чтение. Также при удалении строк, связанных с связями с дочерними таблицами.
Это скорее частный случай, чем универсальный выход.
0
|
|
|
0 / 0 / 0
Регистрация: 15.06.2009
Сообщений: 15
|
|
| 13.07.2009, 18:31 | |
|
та да - это я уже понял...
просто очень хотелось бы сделать такую универсальную штуку, типа собственного CommandBuilder'а с открытым кодом... но что-то пока не получается...
0
|
|
|
21 / 14 / 5
Регистрация: 21.02.2013
Сообщений: 713
|
||||||
| 25.08.2016, 07:35 | ||||||
|
Народ, я сделал соединение с помощью DataSoource.. Form1_Load содержит лишь строку
0
|
||||||
| 25.08.2016, 07:35 | |
|
Помогаю со студенческими работами здесь
19
Обновление свойств компонентов на обновление состояния родителя Обновление релиза и обновление Типовой конфигураци Обновление Обновление бп на 3.0 Обновление ПО Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях.
Задача: при копировании документа очищать определенные реквизиты и табличную. . .
|
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git
main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели
8ATzM_2aurI
|
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2.
Задача: запретить редактирование документа, если он открыт у другого пользователя.
/ / . . .
|
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои.
А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
|
|
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20%
kYBz3eJf3jQ
|
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
|
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
|
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора
Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2.
Задача: уведомлять пользователя, если. . .
|