|
0 / 0 / 0
Регистрация: 31.08.2010
Сообщений: 148
|
|
Update сложного запроса07.12.2010, 09:18. Показов 2164. Ответов 17
Метки нет (Все метки)
Можно ли в Net сохранять обратно в источник данных, ксли этот источник - запрос с join-ами?
У меня досих пор не получается. В MSDN одни простые приемры. Валится в месте, где SqlCommandBuilder генерит GetUpdateCommand.
0
|
|
| 07.12.2010, 09:18 | |
|
Ответы с готовыми решениями:
17
Созтавление сложного запроса
Создание сложного запроса. |
|
1 / 1 / 5
Регистрация: 29.11.2008
Сообщений: 179
|
|
| 07.12.2010, 19:02 | |
|
И не получится
![]() SQLCommandBuilder не всегда может сгенерить UpdateCommmand, точнее говоря не для всех исходных SelectCommand (подробно об этом есть в справке по SQLCommandBuilder) и приходится генерировать Update, Delete, Insert команды головой.
0
|
|
|
0 / 0 / 0
Регистрация: 31.08.2010
Сообщений: 148
|
|
| 08.12.2010, 08:21 [ТС] | |
|
Да я и не против это сделать головой. Тем более, заня ключ таблицы, это сделать не сложно. Просто появляется необходимость определять Sql-ный тип каждой колонки, а в DataSet-е Net-а этого нет, только обычныйе типы (System.String и т.п.). Я уже не говорю про необходимость определять (исходя из этого типа) ставить кавычки по бокам данных каждой обновляемой колонки или нет.
0
|
|
|
0 / 0 / 0
Регистрация: 14.11.2010
Сообщений: 67
|
|
| 08.12.2010, 09:35 | |
|
Что-то меня терзают смутные подозрения, что с join-ами апдейтить, инсертить и делетить совем нельзя (хоть в ADO, хоть в ADO.NET).
Запрос на апдейт должен содержать 1 таблицу. С уважением SerP.
0
|
|
|
0 / 0 / 0
Регистрация: 31.08.2010
Сообщений: 148
|
|
| 08.12.2010, 09:39 [ТС] | |
|
Насчет ADO это они тебя зря терзают. Там это сделать можно. А вот в Net пока немогу разобраться. Но скорее всего тоже можно.
0
|
|
|
Ghost
|
|
| 08.12.2010, 09:44 | |
|
низзя. нигде низзя.
желающие найти можно - внимательно читаем документацию на установленный у них SQL |
|
|
0 / 0 / 0
Регистрация: 31.08.2010
Сообщений: 148
|
|
| 08.12.2010, 09:53 [ТС] | |
|
Не знаю что это за документация такая, но в 6Basice я это вовсю использовал
0
|
|
|
Ghost
|
|
| 08.12.2010, 09:58 | |
|
))) тогда какие проблемы? берешь тот же код, портируешь в DotNet и юзаешь на здоровье.
|
|
|
0 / 0 / 0
Регистрация: 31.08.2010
Сообщений: 148
|
|
| 08.12.2010, 10:01 [ТС] | |
|
Интересно посмотреть как кто-нибуть будет 'портировать' технологию Recordset-а в технологию DataAdapter-а
0
|
|
|
Ghost
|
|
| 08.12.2010, 10:04 | |
|
прошу пример кода в студию
|
|
|
Ghost
|
|
| 08.12.2010, 10:05 | |
|
а что - ADO в .NET неподключаем?
|
|
|
0 / 0 / 0
Регистрация: 31.08.2010
Сообщений: 148
|
|
| 08.12.2010, 10:06 [ТС] | |
|
(а что - ADO в .NET неподключаем?)
Recordset - прошлый век А код сейчас нарою
0
|
|
|
0 / 0 / 0
Регистрация: 31.08.2010
Сообщений: 148
|
|
| 08.12.2010, 10:29 [ТС] | |
|
Вырвать это функциональность из моего навороченного класса неудалось. Но смыл такой, что если в получившемся рекордсете есть по ключу для каждой табоицы, то UpdateBatch все должен обновить
0
|
|
|
Ghost
|
|
| 08.12.2010, 11:14 | |
|
возможно, но ... 'не верю я в стойкость юных, не бреющих бороды'
оно работает, но не всегда. Пробовал на Access - руками - можно, запросом - не пошло. так что лучше, как советовали коллеги выше, делать отдельные апдэйты на каждую таблицу отдельно. Как я понимаю - если VB/ADO такой умный, то он делает тоже самое, БД таких шуток не понимает - она тупая. И это правильно. Насчет прошлого века... согласен, но! если инструмент решает требуемую от него задачу, а изменений не предвидится, то не вижу смысла менять инструмент. ) |
|
|
0 / 0 / 0
Регистрация: 31.08.2010
Сообщений: 148
|
|
| 08.12.2010, 11:17 [ТС] | |
|
Делов том, что не 'решает требуемую от него задачу', ну, разве что Update
![]() Без DataSeta мне не обойтись никак
0
|
|
|
Ghost
|
|
| 08.12.2010, 11:45 | |
|
А чем плох update раздельно? Вероятно - это наиболее оптимальный вариант.
|
|
|
0 / 0 / 0
Регистрация: 31.08.2010
Сообщений: 148
|
|
| 08.12.2010, 12:00 [ТС] | |
|
В смысле Update в ручную?
В принципе да. Это даже более гибко. И Sql даже позволяет указывать int в кавычках. Можно не парится и в них указывать все поля. Но как быть с Image или, там, с Binary. Как, интерестно, сам SqlCommandBuilder аддейтит поля Image.
0
|
|
|
Ghost
|
|
| 09.12.2010, 19:30 | |
|
а какие тут проблемы? делаешь опять-таки несколько запросов, можно запрос наложить непосредственно на таблицу.
|
|
| 09.12.2010, 19:30 | |
|
Помогаю со студенческими работами здесь
18
Построение сложного запроса
Рефакторинг сложного LINQ запроса Выполнение сложного запроса в ADOQuery Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
|
Установка Emscripten SDK (emsdk) и CMake на Windows для сборки C и C++ приложений в WebAssembly (Wasm)
8Observer8 30.01.2026
Чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. Система контроля версиями Git. . .
|
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
|
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования.
Часть библиотеки BedvitCOM
Использованы. . .
|
|
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога
SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
|
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога
SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
|
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
|
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога
SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
|