Модераторы: skyboy
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> посчитать новый или повторный 
:(
    Опции темы
theanton3399
Дата 30.5.2017, 23:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 3
Регистрация: 30.5.2017

Репутация: нет
Всего: нет



привет! Никак не могу придумать алгоритм как сосчитать в number_of_loan колличество совпадений по переменной r_client_id. В экселе легко получилось сделать скользящей формулой, а в mysql не могу никак сообразить. У кого есть идеи. пожалуйста, поделитесь)
user posted image

Присоединённый файл ( Кол-во скачиваний: 2 )
Присоединённый файл  T4aBxxtA2to.jpg 95,14 Kb
PM MAIL   Вверх
Akina
Дата 31.5.2017, 08:55 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20570
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 106
Всего: 453



Ну вариантов два. 

Первый - использовать две копии таблицы, связанные по равенству r_client_id и превышению r_loan_id, группировать по первой копии и считать количетсво по второй.

Второй - использовать две переменные, одну для подсчёта, вторую для хранения r_client_id предыдущей записи.


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
theanton3399
Дата 31.5.2017, 13:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 3
Регистрация: 30.5.2017

Репутация: нет
Всего: нет



это нужно писать процедуру или можно встроенной функцией?


Это сообщение отредактировал(а) theanton3399 - 31.5.2017, 13:51
PM MAIL   Вверх
Snowy
Дата 31.5.2017, 18:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Модератор
Сообщений: 11363
Регистрация: 13.10.2004
Где: Питер

Репутация: 1
Всего: 484



Код

select c.id, c.r_client_id, c.r_loan_id, c.number_of_loan, c.id=cc.f_id as new, c.id<>cc.f_id as repeated from
  (select r_client_id, min(id) f_id from my_table group by r_client_id) cc
join my_table c on c.r_client_id=cc.r_client_id
order by c.id

PM MAIL   Вверх
Akina
Дата 31.5.2017, 19:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20570
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 106
Всего: 453



И то, и другое делается одним запросом.


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
theanton3399
Дата 2.6.2017, 20:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 3
Регистрация: 30.5.2017

Репутация: нет
Всего: нет



Цитата(Snowy @ 31.5.2017,  18:43)
Код

select c.id, c.r_client_id, c.r_loan_id, c.number_of_loan, c.id=cc.f_id as new, c.id<>cc.f_id as repeated from
  (select r_client_id, min(id) f_id from my_table group by r_client_id) cc
join my_table c on c.r_client_id=cc.r_client_id
order by c.id

Error Code: 1054. Unknown column 'id' in 'field list'    0.391 sec
У меня как первичный ключ выбрано r_loan_id, менять его на id  auto_increment?
PM MAIL   Вверх
Akina
Дата 2.6.2017, 21:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20570
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 106
Всего: 453



Эххх... 

Код

select * from 
(
    select t1.*,
           if(@temp=t1.r_client_id, 
              @rownum:=@rownum+1, 
              @rownum:=1+least(0,@temp:=t1.r_client_id)) number_of_loan
    from MyTable t1, (select @rownum:=1, @temp:='_') t2
    order by r_client_id, r_loan_id 
) t3;



--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | MySQL | Следующая тема »


 




[ Время генерации скрипта: 0.1425 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.