SELECT prices.*
FROM prices
JOIN ( SELECT size, MAX(`date`) AS `date`
FROM prices
WHERE price
-- AND `date` <= @some_date
GROUP BY size ) AS last_nonzero_date USING (size, `date`);
(size, `date`)
- уникально.SELECT MIN(`min_price`) OVER () as `min_price`,
MAX(`max_price`) OVER () as `max_price`,
`item_id` as `id`
FROM `product_table`
WHERE `id` IN (SELECT тут запрос)
Akina, да, версия 5.7.21 и она, я так понимаю, не поддерживает оконные функции.
SELECT t2.min_price,
t2.max_price,
t1.item_id as id
FROM product_table t1
CROSS JOIN ( SELECT MIN(min_price) AS min_price,
MAX(max_price) AS max_price
FROM product_table ) t2
WHERE t1.id IN (SELECT тут запрос)
Есть папка, которая хранит в себе sql файлы для создания бд, таблиц в этой бд, импорт данных в эти таблицы.
Как автоматизировать запуск этих sql скриптов?
нужно удалить записи с одинаковыми date и user_id
DELETE t1.*
FROM tablename t1
JOIN tablename t2 USING (date, user_id)
WHERE t1.id > t2.id
а лучше не создавать их
CREATE UNIQUE INDEX indexname ON tablename (date, user_id)
SELECT CASE WHEN sender_id = 1
THEN receiver_id
ELSE sender_id
END AS buddy
FROM message
WHERE 1 IN (sender_id, receiver_id)
GROUP BY buddy
ORDER BY MAX(sent_at)
SELECT user.username
FROM user
JOIN ( SELECT CASE WHEN sender_id = 1
THEN receiver_id
ELSE sender_id
END AS id,
MAX(sent_at) sent_at
FROM message
WHERE 1 IN (sender_id, receiver_id)
GROUP BY 1 ) ids USING (id)
ORDER BY ids.sent_at
SELECT DISTINCT (regexp_split_to_array(commend, E'\\s+'))[:3] AS first_3_words
FROM orders
ORDER BY first_3_words[2];
SELECT DISTINCT
key,
FIRST_VALUE(value1) OVER (PARTITION BY key
ORDER BY CASE WHEN value1 IS NULL
THEN 1
ELSE 0 END, id DESC) AS value1,
FIRST_VALUE(value2) OVER (PARTITION BY key
ORDER BY CASE WHEN value2 IS NULL
THEN 1
ELSE 0 END, id DESC) AS value2,
FIRST_VALUE(value3) OVER (PARTITION BY key
ORDER BY CASE WHEN value3 IS NULL
THEN 1
ELSE 0 END, id DESC) AS value3
FROM tablename
-- WHERE key IN ( {список значений} )
переписать таблицу в нормальную форму
SELECT `p`.`sum`, `p`.`type`, `p`.`visit`
FROM `visits` AS `v`
JOIN `payments` AS `p` ON `v`.`id` = `p`.`visit`
WHERE DATE(p.date) = '2021-10-04' AND `v`.`office` = '1'
SELECT `p`.`sum`, `p`.`type`, `p`.`visit`
FROM `visits` AS `v`
JOIN `payments` AS `p` ON `v`.`id` = `p`.`visit`
WHERE p.date >= '2021-10-04'
AND p.date < '2021-10-05'
AND `v`.`office` = '1'
visits (office, id)
.payments (`date`, visit)
и payments (visit, `date`)
, посмотреть какой из них используется, удалить неиспользуемый.AND `v`.`office` = 1
. В исходном виде, если поле числовое, то и поле, и значение приводятся к floating-point number, и только потом сравниваются. SELECT p.*, GROUP_CONCAT(c.name) countries
FROM p
JOIN с ON FIND_IN_SET(c.id, p.country)
GROUP BY p.id
Например, пишу я такой SELECT и все нормально
SELECT Trip.plane, Trip.id
Но при таком мне выдает ошибку
SELECT Trip.plane, COUNT(Trip.plane) planes
Откуда это берется вообще? /*!40001 SQL_NO_CACHE */ и как это убрать?
/*!
) - код из комментария обрабатывается любой версией.В голове идея создать varchar ячейку и в неё через запятую всё записывать.
CREATE TABLE words (
word_id INT AUTO_INCREMENT PRIMARY KEY,
word VARCHAR(255) UNIQUE NOT NULL
);
CREATE TABLE phrase (
phrase_id INT NOT NULL,
FOREIGN KEY (phrase_id) REFERENCES phrases (phrase_id),
word_id INT NOT NULL,
FOREIGN KEY (word_id) REFERENCES words (word_id),
word_position INT,
PRIMARY KEY (phrase_id, word_position)
);
INSERT ... VALUES ( ... , CAST(REPLACE(@value, ',', '.') AS DOUBLE), ...