Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
1 / 1 / 0
Регистрация: 19.08.2013
Сообщений: 163

Почему при другой дате брони дефрагментируются неверно?

16.12.2016, 23:50. Показов 650. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Я пытаюсь дефрагментировать свою базу данных. Она выглядит вот так: http://sqlfiddle.com/#!9/9554b . Первая таблица отвечает за отображение номеров в гостинице, которые существуют, вторая - за существующие брони в гостинице. Если её визуализировать, то выглядит эту чудо вот так:

Дефрагментировать - значит расположить брони (выделенное цветом - это брони) так, чтобы они были максимально приближены друг к другу, то есть вот так:

И вот этот код с моей задачей справляется:
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
SET @today:=DATE('2016-12-11');
UPDATE main M
  JOIN (
   SELECT cid, nomer
     FROM (
       SELECT A.nomer,
              @cstart:=IF(@cnum=A.nomer,@cstart,A.start),
              @cnum:=A.nomer,
              @cid:=(SELECT M.id
                       FROM main M,allnomer MT
                      WHERE MT.nomer=M.numbernomer AND MT.type='lux'
                        AND M.datestart>@cstart
                        AND find_in_set(M.id,@used)=0
                      ORDER BY datestart
                      LIMIT 1
                    ) cid,
              @cstart:=(SELECT dateend FROM main WHERE id=@cid) dend,
              @used:=COALESCE(concat(@used,',',@cid),@used)
         FROM (
          SELECT A.nomer, A.start
            FROM (
              SELECT A.nomer,
                     (SELECT COALESCE(MIN(dateend),@today-INTERVAL 1 DAY)
                        FROM main M
                       WHERE datestart<=@today AND M.numbernomer=A.nomer) START
                FROM allnomer A WHERE TYPE='lux'
            ) A,
            main M, allnomer MT
           WHERE MT.nomer=M.numbernomer AND MT.type='lux' AND M.datestart>A.start
           ORDER BY A.start DESC, A.nomer
         ) A,
         (SELECT @cid:=0,@cnum:=0,@cstart:=NULL,@used:='') Y
     ) X WHERE cid IS NOT NULL
  ) U
  ON M.id=U.cid
SET M.numbernomer=U.nomer
Но если изменить set @today:=date('2016-12-11'); на set @today:=date('2016-12-05'); , то база данных будет выглядеть вот так:

Почему при смене даты происходит неверная дефрагментация? Подскажите, как исправить?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
16.12.2016, 23:50
Ответы с готовыми решениями:

По дате 23.04.2039 или другой дате XXI века определить день недели
&quot;Вечный календарь&quot;. По дате 23.04.2039 или другой дате XXI века оп-ределить день недели. Напечатать календарь на текущий месяц.

Почему так странно отбираются записи при селекции по дате?
Код моего запроса SELECT orders.* FROM orders WHERE orders.date &gt; 2020 - 01 - 01 ORDER BY orders.date DESC я ожидал что...

Почему доказательство неверно
Анализ алгоритма декомпозиции для задачи о нахождении пары ближайших точек на плоскости: http://e-maxx.ru/algo/nearest_points Оценка...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
16.12.2016, 23:50
Помогаю со студенческими работами здесь

Почему категории сортируются неверно?
Всем привет. В каталоге товаров почему-то категории сортируются не верно, не так как выставлена сортировка в админке. Почему? ...

Почему неверно , и как переделать ?
uses crt; var n:integer; i:real; function p(n:integer):integer; begin

Почему код работает неверно?
Переведенный код namespace atbash { /// &lt;summary&gt; /// Description of MainForm. /// &lt;/summary&gt; public partial class MainForm...

Почему неверно считается интеграл?
Собственно есть дифференциальное уравнение 4-го порядка вида: y'''' = -24 Далее я его решаю через интегралы, т.е. для y''' = \int...

Почему строка неверно преобразуется в число?
Задача Эйлера номер 8. Почему у меня неправильно отображаются элементы массива?? при преобразовании из строки в массив интов выдает бред...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение/ Перевод Сайт называется reddit: The Thinkpad X220 Tablet is the best budget school laptop period. Это. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru