Форум программистов, компьютерный форум, киберфорум
MySQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.72/75: Рейтинг темы: голосов - 75, средняя оценка - 4.72
1 / 1 / 0
Регистрация: 20.05.2020
Сообщений: 14

Случайная дата RAND()

11.08.2020, 08:58. Показов 15716. Ответов 2

Студворк — интернет-сервис помощи студентам
Добрый день! Пишу скрипт для заполнения БД, сам скрипт ниже:
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
USE shop;
 
 DELIMITER $$
CREATE PROCEDURE prepare_data()
BEGIN
 DECLARE i INT DEFAULT 4;
 WHILE i <= 100 DO
 INSERT INTO productscategories (id, name)
 VALUES (i, CONCAT('Категория ', i));
 SET i = i + 1;
  END WHILE;
 WHILE i <= 5000 DO
 INSERT INTO products (id, name, price, categoryId, dateOfManufacture)
 VALUES (i + 1, CONCAT('Товар ', i + 1), FLOOR(RAND() * (200 - 10) + 10), FLOOR(RAND() * (100 - 1) + 1), RAND() * (DATE('2020-08-11') - DATE('2018-01-01')) + DATE('2018-01-01'));
 SET i = i + 1;
 END WHILE;
END$$
DELIMITER ;
Проблема в том, что не получается рандомно задать дату. Пробовала вот так: RAND() * (DATE('2020-08-11') - DATE('2018-01-01')) + DATE('2018-01-01')); и всяко разно уже.
Появляется ошибка: Error Code: 1292. Incorrect date value: '20184767.377671424' for column 'dateOfManufacture' at row 1 3.343 sec.
Что делать, подскажите, пожалуйста, кто разбирается
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
11.08.2020, 08:58
Ответы с готовыми решениями:

Случайная последовательность чисел, генерируемой rand() функцией
Как можно из псевдослучайно последовательности сделать случайную-последовательность числе, генерируемую rand() функцией?

Случайная дата
Здравствуйте ,у меня такой вопрос. Я хочу заполнить таблицу в Аксесе случайными данными из Матлаба, с числовыми значениями не возникло...

Случайная дата в заданном временном диапазоне
Доброе утро. Подскажите знающие люди - решение. В ячейки C3 и E3 - вписаны текстом - определенные даты. Как макросом - вписать в...

2
541 / 352 / 194
Регистрация: 07.11.2018
Сообщений: 1,243
11.08.2020, 11:01
Цитата Сообщение от LibertaTatyana Посмотреть сообщение
(DATE('2020-08-11') - DATE('2018-01-01'))
так не вычисляется разница в днях..для этого есть функция
https://www.w3schools.com/sql/... tediff.asp
а что вы хотите подставить рандомно ? день? час? год?все сразу не получится ведь рандом возвращает число а не дату.Есть также функции которые из даты вытаскивают дни месяцы и тд..вот тогда уже можно использовать рандом на каждую из этих частей.https://www.w3schools.com/sql/func_mysql_month.asp

думаю тут какраз нужный вам ответhttps://stackoverflow.com/ques... e-in-mysql
0
490 / 167 / 98
Регистрация: 23.01.2020
Сообщений: 324
11.08.2020, 11:05
LibertaTatyana, Здравствуйте, формула для расчета рандомного числа из диапазона примерно такая:

Code
1
ROUND((RAND() * (max-min))+min)
Попробуйте запустить такой запрос отдельно несколько раз:

SQL
1
SELECT FROM_UNIXTIME(ROUND((RAND() * (UNIX_TIMESTAMP('2020-08-11')-UNIX_TIMESTAMP('2018-01-01')))+UNIX_TIMESTAMP('2018-01-01')));
в итоге будем получать рандомную дату (и время тоже) из вашего диапазона дат. Если нужно без времени почитайте как форматировать даты в MySql.

Вот мои тестовые запуски:
Code
1
2
3
4
18.02.2018 03:39:46
07.10.2018 10:09:08
14.10.2019 01:31:41
04.06.2019 21:46:23
Я не особо сильно шарю в запросах, возможно есть более простое решение))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
11.08.2020, 11:05
Помогаю со студенческими работами здесь

Access запрос Есть два поля : дата начало и дата окончания
Есть два поля : дата начало и дата окончания. Если дата находиться в диапазоне то нужно выводить в поле &quot;важность&quot; запись...

Открыть файл по параметрам: Дата создания, Дата изменения , Размер
Добрый день уважаемые господа программисты. Кто сталкивался с подобной задачей?: Необходимo открыть файл .txt на Autoit не...

Дата хранится в виде записи; определить, какая дата будет через А дней
Сегодняшняя дата хранится в записи с тремя полями. Определить, какая дата будет через А дней.

Узнать количество дней (дата заезда и дата отъезда)
Есть 2 dateTimePicker: dateTimePicker1 - Дата заезда dateTimePicker2 - Дата отъезда Нужно узнать количество дней между датой...

Дана дата из трех чисел (день, месяц и год). Вывести yes, если такая дата существует
Здравствуйте. Помогите пожалуйста написать программу. Дана дата из трех чисел (день, месяц и год). Вывести yes, если такая дата существует...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru