|
|
|
Помогите пожалуйста с запросом...
|
|||
|---|---|---|---|
|
#18+
Существует таблица Table1{id, nomer1, nomer2, descript} в неё занесены следующие данные id | nomer1 | nomer2 | descript -------------------------------- 1 | ....1.... | ....2....| ..text.. 2 | ....1.... | ....3....| ..text.. 3 | ....1.... | ....2....| ..text.. 4 | ....2.... | ....4....| ..text.. 5 | ....2.... | ....4....| ..text.. 6 | ....3.... | ....5....| ..text.. 7 | ....3.... | ....5....| ..text.. Нужно выбрать строки у которых одинаковый nomer1 и есть различные nomer2, в данной таблице это будут строки 1,2,3. Например, когда есть таблица с "Продажами клиентам" (номер1 -это тип дисконтной карты, номер2- это номер отдела продаж) и нужно выбрать клиентов которые по одному типу дисконтной карты покупали в разных отделах продаж. Чего-то не могу сообразить, как запрос сделать... ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 04.07.2004, 08:26:08 |
|
||
|
Помогите пожалуйста с запросом...
|
|||
|---|---|---|---|
|
#18+
Может быть так? Идея - в первом запросе найти мин или мах nomer2 и сравнить это значение в основном запросе. Код: plaintext 1. 2. 3. 4. 5. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 04.07.2004, 09:41:45 |
|
||
|
Помогите пожалуйста с запросом...
|
|||
|---|---|---|---|
|
#18+
Код: plaintext 1. 2. 3. 4. 5. 6. 7. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 04.07.2004, 09:44:41 |
|
||
|
Помогите пожалуйста с запросом...
|
|||
|---|---|---|---|
|
#18+
Спасибо, большое)) (c)VIG, этот код в версии Access 2000/XP работает на ура, а в версии 97 выдаёт ошибку синтаксиса (в предложении From) как можно поправить для версии 97 ? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 05.07.2004, 09:58:14 |
|
||
|
Помогите пожалуйста с запросом...
|
|||
|---|---|---|---|
|
#18+
Попробуй вложенные селекты сохранить как отдельные запросы и работать с ними. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 05.07.2004, 10:06:36 |
|
||
|
Помогите пожалуйста с запросом...
|
|||
|---|---|---|---|
|
#18+
Romires*Спасибо, большое)) (c)VIG, этот код в версии Access 2000/XP работает на ура, а в версии 97 выдаёт ошибку синтаксиса (в предложении From) как можно поправить для версии 97 ? Подзапросы в предложении from выделяешь след. образом select ... from [ подзапрос ]. as ... where ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 05.07.2004, 10:14:56 |
|
||
|
Помогите пожалуйста с запросом...
|
|||
|---|---|---|---|
|
#18+
авторИдея - в первом запросе найти мин или мах nomer2 и сравнить это значение в основном запросе. Исходя из идеи :) Код: plaintext 1. 2. 3. 4. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 05.07.2004, 10:19:04 |
|
||
|
Помогите пожалуйста с запросом...
|
|||
|---|---|---|---|
|
#18+
SELECT Таблица1.Поле1, Count(Таблица1.Поле2) AS [Count-Поле2] FROM Таблица1 GROUP BY Таблица1.Поле1 HAVING (((Count(Таблица1.Поле2))>1)); ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 05.07.2004, 10:33:57 |
|
||
|
Помогите пожалуйста с запросом...
|
|||
|---|---|---|---|
|
#18+
SharkSELECT Таблица1.Поле1, Count(Таблица1.Поле2) AS [Count-Поле2] FROM Таблица1 GROUP BY Таблица1.Поле1 HAVING (((Count(Таблица1.Поле2))>1)); Это не соответствует вопросу - во всех nomer1 количество nomer2 больше 1. Поэтому запрос вернет все три кода, а должен только 1 ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 05.07.2004, 10:47:48 |
|
||
|
Помогите пожалуйста с запросом...
|
|||
|---|---|---|---|
|
#18+
>Несоответствует GROUP BY Поле1(В смысле nomer1) Что такое Group by знаем? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 05.07.2004, 10:57:54 |
|
||
|
Помогите пожалуйста с запросом...
|
|||
|---|---|---|---|
|
#18+
Shark>Несоответствует GROUP BY Поле1(В смысле nomer1) Что такое Group by знаем? И что же такое GROUP BY? Специально построил таблицу и твой запрос: SELECT Table1.nomer1, Count(Table1.nomer2) AS [Count-nomer2] FROM Table1 GROUP BY Table1.nomer1 HAVING (((Count(Table1.nomer2))>1)); Вот что он выдал: nomer1 Count-nomer2 1 3 2 2 3 2 ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 05.07.2004, 11:19:36 |
|
||
|
Помогите пожалуйста с запросом...
|
|||
|---|---|---|---|
|
#18+
:-) Нужно было вернуть набор записей 1 2 3 Это не он? Ну да, лишнее поле есть. Убери его:-) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 05.07.2004, 11:55:24 |
|
||
|
Помогите пожалуйста с запросом...
|
|||
|---|---|---|---|
|
#18+
Блин, сори, я вопрос не понял, это я болван:-) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 05.07.2004, 11:57:39 |
|
||
|
Помогите пожалуйста с запросом...
|
|||
|---|---|---|---|
|
#18+
Лучше обьединить обе идеи :) авторselect table1.* from table1 inner join (select nomer1 from table1 group by nomer1 having min(nomer2)<max(nomer2) ) as t1 on table1.nomer1=t1.nomer1 ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 05.07.2004, 12:56:20 |
|
||
|
Помогите пожалуйста с запросом...
|
|||
|---|---|---|---|
|
#18+
(c)VIGЛучше обьединить обе идеи :) авторselect table1.* from table1 inner join (select nomer1 from table1 group by nomer1 having min(nomer2)<max(nomer2) ) as t1 on table1.nomer1=t1.nomer1 Запрос paparome работает прекрасно! Что еще нужно :) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 05.07.2004, 13:06:37 |
|
||
|
Помогите пожалуйста с запросом...
|
|||
|---|---|---|---|
|
#18+
авторЗапрос paparome работает прекрасно! Что еще нужно :) Да в общем то ничего ,кроме желания оптимизировать :) У paparome два коррелированых подзапроса ,что на больших объёмах может сказаться на быстродействии ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 05.07.2004, 13:16:30 |
|
||
|
|

start [/forum/topic.php?fid=45&msg=32588397&tid=1673423]: |
0ms |
get settings: |
9ms |
get forum list: |
17ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
189ms |
get topic data: |
13ms |
get forum data: |
3ms |
get page messages: |
76ms |
get tp. blocked users: |
2ms |
| others: | 210ms |
| total: | 525ms |

| 0 / 0 |
