Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности
|
|
|
Не могу выбрать нормальный алгоритм хранимой
|
|||
|---|---|---|---|
|
#18+
Здравствуйте. Имеем таблицу Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. Со значениями, к примеру date_det src_ip dst_ip bts 2005-12-07 192.168.8.1 219.243.4.23 5000 2005-12-07 192.168.4.1 219.243.4.23 5000 2005-12-07 219.243.4.23 192.168.8.1 5000 Задача: для каждого локального ip (который может быть как в src_ip, так и в dst_ip) просуммировать bts для всех повторяющихся интернетовских ip по направлениям in и out (т.е. если src_ip <<='192.168.0.0/16', то bts будет направление out) за определенную дату. Т.е. на выходе нужно получить таблицу вида: date src dst in out 2005-12-07 192.168.8.1 219.243.4.23 5000 5000 2005-12-07 192.168.4.1 219.243.4.23 5000 Поразмыслив, я не придумал ничего кроме следующего: 1) Вытащить список локальных ip 2) Вытащить список инетовых ip 3) Цикл перебора списка локальных ип, вложенный цикл перебора инетовых ип, в котором уже в свою очередь идет выборка всех таких же локальных и инетовых ип, расставляется направление и считается сумма. Это все в принципе можно сделать функцией. Вопрос надо ли это делать функцией и можно ли как-то это сделать лучше? До этого я пытался проводить заполнение второй таблицы на ходу с помощью триггера , но сейчас ясно, что это неправильно. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 07.12.2005, 15:15 |
|
||
|
Не могу выбрать нормальный алгоритм хранимой
|
|||
|---|---|---|---|
|
#18+
По-моему, вполне можно решить след. запросами: Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 07.12.2005, 15:39 |
|
||
|
Не могу выбрать нормальный алгоритм хранимой
|
|||
|---|---|---|---|
|
#18+
Или даже одним запросом :) Код: plaintext 1. 2. 3. 4. 5. 6. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 07.12.2005, 15:59 |
|
||
|
|

start [/forum/topic.php?fid=53&fpage=331&tid=2006810]: |
0ms |
get settings: |
7ms |
get forum list: |
12ms |
check forum access: |
2ms |
check topic access: |
2ms |
track hit: |
32ms |
get topic data: |
10ms |
get forum data: |
2ms |
get page messages: |
27ms |
get tp. blocked users: |
1ms |
| others: | 269ms |
| total: | 364ms |

| 0 / 0 |
