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

Вниз

Копирование таблицы   Найти похожие ветки 

 
VadimSpb   (2005-11-25 15:00) [0]

Здравствуйте!
Копирую содержимое одной таблицы в другую из Д7 запросом в Access. Как исключить копирование строки, если в первой таблице уже существует такая же строка?


 
alex_*** ©   (2005-11-25 15:07) [1]

подзапросом


 
VadimSpb   (2005-11-25 15:15) [2]

Перепробовал разные варианты, но увы :-((
Скопировать все подзапросом проблем нет, а как не копировать уже существующие строки?
Примерчика нет?


 
msguns ©   (2005-11-25 16:05) [3]

Примерно так:

INSERT INTO FONDSR
 (Letter, FondNumber, FondType, Category,
  AFID, AArcID, ACountry, ASDate, AEDate,
  AFSize, AQDI, AQMF, AQS, AAvl, APassT, APassL, APassN,
  AJoinL, AJoinN, AUtil, ALossID, ALossDt, ALossDc)
 SELECT Letter, FondNumber, FondType, Category,
    FID, ArcID, Country, StartDate, EndDate,
    FondSize, DontInvent, MicroFished, Secret, Availability,
    PassTo, PassLetter, PassNumber, JoinLetter, JoinNumber,
    UtilDate, LossCauseID, LossDate, LossDoc
   FROM FONDS1
     WHERE FID NOT IN
       (SELECT F1.FID FROM FONDS1 F1, FONDS0 F0
         WHERE F1.Letter=F0.Letter AND
               F1.FondNumber=F0.FondNumber AND
               F1.FondType=F0.FondType AND
               F1.Category=F1.Category)


 
VadimSpb   (2005-11-25 21:06) [4]

Как я понимаю, здесь
    WHERE FID NOT IN
      (SELECT F1.FID FROM FONDS1 F1, FONDS0 F0
        WHERE F1.Letter=F0.Letter AND
              F1.FondNumber=F0.FondNumber AND
              F1.FondType=F0.FondType AND
              F1.Category=F1.Category)

проверяется, что FID не входит в некое представление из F1 и F0 и тогда происходит запись в FONDSR
Два вопроса:
1. Мне необходимо проверять наличие записи непосредственно в FONDSR. Как в этом случае?
2. Подобное я пробовал, но оказывалось следующее. Если присутствует хотя бы одна проверяемая запись во всей таблице, то копирование не происходит. А надо проверять только строку!


 
msguns ©   (2005-11-28 09:39) [5]

>1. Мне необходимо проверять наличие записи непосредственно в FONDSR. Как в этом случае?

Пример дан для образца. В твоем случае все много проще:
Что-то вроде

INSERT INTO T2 (F1...)
  SELECT F1... FROM T1
   WHERE  T1.ID NOT IN
     (SELECT ID FROM T2)

>2. Подобное я пробовал, но оказывалось следующее. Если присутствует хотя бы одна проверяемая запись во всей таблице, то копирование не происходит. А надо проверять только строку!

Что такое у тебя запись, а что такое строка ? Счетчики в таблицах не используются ?


 
VadimSpb   (2005-11-28 12:58) [6]

Спасибо, все работает. Разобрался с условиями ;-))



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

Форум: "Базы";
Текущий архив: 2006.01.29;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.46 MB
Время: 0.041 c
3-1133208408
Alexandr Bydantcev
2005-11-28 23:06
2006.01.29
Постоянное увеличение объема базы


15-1135260417
Piter
2005-12-22 17:06
2006.01.29
Лукьяненко - "Последний Дозор"


1-1135319886
jiny
2005-12-23 09:38
2006.01.29
Как узнать наличие переменной на другом фрейме не зная названия


1-1135248421
Chaser
2005-12-22 13:47
2006.01.29
Как заблокировать форму


3-1132924137
Антоний
2005-11-25 16:08
2006.01.29
Проблема при выборке с некоторыми буквами





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский