Форум программистов, компьютерный форум, киберфорум
Visual Basic .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.55/11: Рейтинг темы: голосов - 11, средняя оценка - 4.55
0 / 0 / 0
Регистрация: 31.08.2010
Сообщений: 148

Update сложного запроса

07.12.2010, 09:18. Показов 2164. Ответов 17
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Можно ли в Net сохранять обратно в источник данных, ксли этот источник - запрос с join-ами?
У меня досих пор не получается. В MSDN одни простые приемры.
Валится в месте, где SqlCommandBuilder генерит GetUpdateCommand.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.12.2010, 09:18
Ответы с готовыми решениями:

Созтавление сложного запроса
Здравствуйте! Уже вторые сутки не могу справиться с задачей, поэтому решил обратиться к знающим. И так, есть таблица: ...

Реализация сложного запроса
Добрый день. Существует таблица участников (users): Таблица1 id | event_a | event_b | promo | action 1 | 1 | 0 | | 1 2 | 1 |...

Создание сложного запроса.
Помогите, пожалуста создать запрос. Получается очень сложным (даже теряюсь при создании): Есть таблица Осмотр (где указаны №осмотра...

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
а какие тут проблемы? делаешь опять-таки несколько запросов, можно запрос наложить непосредственно на таблицу.
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
09.12.2010, 19:30
Помогаю со студенческими работами здесь

Составление сложного запроса
Всем доброго времени суток, помогите составить запрос, в котором будет выводится количество товаров, которые находятся на складе 1, 1-2,...

Построение сложного запроса
Есть 4 таблицы в Акцесе (Заказы, Отгрузка, Склад, Позиции), связанны через таблицу Заказы по полю номер_заказа 1:M. Нужно построить запрос...

Создание сложного запроса
Добрый вечер, друзья! Настала необходимость написать запрос, но он оказался сильнее меня:jokingly:. Прошу вашей помощи :) Нужно создать...

Рефакторинг сложного LINQ запроса
Есть очень большой и запутанный запрос. Хочу его разобрать на более мелкие запросы и вынести их в отдельные методы. Но столкнулся с такой...

Выполнение сложного запроса в ADOQuery
Хочу выполнить запрос fmMain.ADODelDel.SQL.Text:='delete from posts where id_pr in (select id_pr where status=''удален'')'; ...


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

Или воспользуйтесь поиском по форуму:
18
Ответ Создать тему
Новые блоги и статьи
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 - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru