Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности
|
|
|
как правильно удалить
|
|||
|---|---|---|---|
|
#18+
здравствуйте вопрос такой: как правильно удалить мне записи которые повторяютя сразу в трех полях т.е. есть база plat.dbf с полями fam c(20), name c(10), otch c(15), sum_pl c(10,2), mes n(2), god c(4) мне нужно удалить записи которые встречаются больше одного раза ПРИМЕР если в полях nam c(20), name c(10), otch c(15) с значением nam , name , otch ИВАНОВ ИВАН ИВАНОВИЧ встречается запись nam , name , otch ИВАНОВ ИВАН ИВАНОВИЧ или nam , name , otch ИВАНОВ ПЕТР ИВАНОВИЧ то ИВАНОВ ИВАН ИВАНОВИЧ удалить обоих а оставить только ИВАНОВ ПЕТР ИВАНОВИЧ ВООБЩЕ ТО ЭТО КОМАНДА SELECT fam, name, otch, COUNT(*) FROM plat GROUP BY 1,2,3 HAVING COUNT(*)>1 МНЕ ВЫВОДИТ ТАК НАЗЫВАЕМЫХ ДВОЙНИКОВ, НО КАК ИХ УДАЛИТЬ ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 13.10.2004, 00:36 |
|
||
|
как правильно удалить
|
|||
|---|---|---|---|
|
#18+
ГЕОРГИЙ18здравствуйте вопрос такой: как правильно удалить мне записи которые повторяютя сразу в трех полях мне нужно удалить записи которые встречаются больше одного раза ВООБЩЕ ТО... КОМАНДА SELECT fam, name, otch, COUNT(*) FROM plat GROUP BY 1,2,3 HAVING COUNT(*)>1 МНЕ ВЫВОДИТ ТАК НАЗЫВАЕМЫХ ДВОЙНИКОВ, НО КАК ИХ УДАЛИТЬ А дальше все просто: ВАРИАНТ 1: Внешний цикл: Код: plaintext 1. 2. 3. 4. 5. Внутренний цикл: Код: plaintext 1. 2. 3. 4. ВАРИАНТ 2: Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. ВАРИАНТ 3: Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 13.10.2004, 07:23 |
|
||
|
как правильно удалить
|
|||
|---|---|---|---|
|
#18+
Для начала, воспользоваться поиском по данному форуму http://www.sql.ru/forum/actualthread.aspx?tid=128155 ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 13.10.2004, 10:38 |
|
||
|
как правильно удалить
|
|||
|---|---|---|---|
|
#18+
ВСЕ СПАСИБО Станислав C. 2 ой вариант подгодит ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 13.10.2004, 15:43 |
|
||
|
как правильно удалить
|
|||
|---|---|---|---|
|
#18+
DELETE FROM plat ; WHERE EXISTS ; (SELECT fam, name, otch ; FROM plat ttt ; WHERE ttt.fam == plat.fam AND ; ttt.name == plat.name AND ; ttt.otch == plat.otch ; GROUP BY 1, 2, 3 ; HAVING COUNT(*) > 1) Версию фокса ты не указал, значит предполагаем наличие VFP8. Posted via ActualForum NNTP Server 1.0 ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 14.10.2004, 02:44 |
|
||
|
как правильно удалить
|
|||
|---|---|---|---|
|
#18+
Ваш вариант тоже правильный, но я не понял что означает команда "EXISTS" в хелпе нет и в книгах я непойму, что означает команда. спасибо Igor Korolyov ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 14.10.2004, 11:17 |
|
||
|
как правильно удалить
|
|||
|---|---|---|---|
|
#18+
ГЕОРГИЙ18Ваш вариант тоже правильный, но я не понял что означает команда "EXISTS" в хелпе нет и в книгах я непойму, что означает команда. спасибо Igor Korolyov EXISTS функцbя SQL. Говорит она о том, что есть ли выборка( в скобках) или нет, Ну это типа Select ... into table/cursor <Name> А потом: If RecCount(<Name>) == 0 Exit Else .... EndIf Так вот EXISTS -> .T. Если RecCount()>0 и -> .F. Если RecCount()==0 ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 14.10.2004, 11:35 |
|
||
|
|

start [/forum/topic.php?fid=41&fpage=356&tid=1595617]: |
0ms |
get settings: |
7ms |
get forum list: |
12ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
53ms |
get topic data: |
10ms |
get forum data: |
3ms |
get page messages: |
33ms |
get tp. blocked users: |
2ms |
| others: | 251ms |
| total: | 377ms |

| 0 / 0 |
