Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Начинающим";
Текущий архив: 2005.12.11;
Скачать: [xml.tar.bz2];

Вниз

Update одной таблицы из другой.   Найти похожие ветки 

 
SergP ©   (2005-11-23 02:50) [0]

Есть 2 таблицы имеющие по 2 идентичных поля.
например:
table1, поля field1, field2 и другие
table2, поля field1, field2 и другие

Нужно обновить значения field2 одной таблицы, значениями field2 из другой для table1.field1=table2.field1
Можно ли это сделать одним запросом update?

Если да, то как? (интересует сам синтаксис запроса)


 
SergP ©   (2005-11-23 02:52) [1]

обновить=изменить.

что-то типа
update .... set table1.field2=table2.field2 where table1.field1=table2.field1 ...


 
sniknik ©   (2005-11-23 09:00) [2]

понятия "синтаксис запроса" в отрыве от движка/sql сервера, диалекта sql считай не существует...

вывод? невозможно, до тех пор пока не будет уточненной инфы по ним.

и кстати если для local sql то запрс в [1] вроде даже вполне нормальный (правда может ругатся если обьеденение по условию table1.field1=table2.field1 дает больше чем 1 результируюшую).


 
SergP ©   (2005-11-23 09:38) [3]

Что касается движка/sql сервера, я ведь указывал что Oracle, но видимо потерялось, когда модератор перенес, не подумавши что при переносе темы потеряется дополнительная информация.

А что касается:


> и кстати если для local sql то запрс в [1] вроде даже вполне
> нормальный (правда может ругатся если обьеденение по условию
> table1.field1=table2.field1 дает больше чем 1 результируюшую).


Ну тут может быть 3 варианта:
1. table2.field1 может иметь повторяющиеся значения
2. Может не иметь повторяющихся значений.
3. Может первичным ключем, либо просто уникальным.

В моем случае 1 вариант не встречается.

А что касается синтаксиса запроса, то меня интересует как его написать полностью (если такое возможно с Update), а то как ни пробовал - не проходит, а в книгах и прочей доке, запросы сложнее чем select из двух таблиц с объединением вообще не рассматриваются и примеров нет.
Например как указывается что в запросе участвуют 2 таблицы, при этом изменения происходят в одной?


 
Sergey13 ©   (2005-11-23 09:43) [4]

update table1
set table1.field2= (select table2.field2 from table2 where table1.field1=table2.field1)
where...

Не то?


 
evvcom ©   (2005-11-23 14:46) [5]

Для оракла есть merge - 3 в одном: и insert, и update, и delete.



Страницы: 1 вся ветка

Форум: "Начинающим";
Текущий архив: 2005.12.11;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.45 MB
Время: 0.06 c
1-1131740281
Snale
2005-11-11 23:18
2005.12.11
Поиск слов в HTML-документе


2-1132551144
KitsumVI
2005-11-21 08:32
2005.12.11
Композитивный класс


6-1121692051
Соловьев
2005-07-18 17:07
2005.12.11
IMAP - тип папки на сервере


3-1130052722
chyp
2005-10-23 11:32
2005.12.11
foreign key и null в Interbase


2-1132814923
tytus
2005-11-24 09:48
2005.12.11
Снова Paskal





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский