Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
6 / 6 / 3
Регистрация: 05.10.2015
Сообщений: 40
.NET 4.x

Запись значения 0 раз в сутки, и раз в месяц

25.01.2016, 13:24. Показов 884. Ответов 5

Студворк — интернет-сервис помощи студентам
Дорогие форумчане, помогите решить проблему (не могу разобраться с временем) есть БД в MySQL и программа на C#
Ситуация следующая :
Есть в БД Строки :
Текущий, Суточный, Месячный
Полная суть вопроса выглядит так
С наступление каждого нового дня Суточные показания сбрасываются на 0
С наступлением каждого месяца первого дня Месячные данные сбрасываются на 0

запрос на заполнение делаю так:
C#
1
2
3
4
5
6
7
8
9
10
string sql1 = string.Format("Insert Into Diet" + "(DataTime, TecCMC, SutCMC, MesCMC) Values(@DataTime, @TecCMC, @SutCMC, @MesCMC)");
MySqlConnection mcon = new MySqlConnection("datasource= localhost; port= 3306; User Id= root; password= 1234; database= schetchik");
                using (MySqlCommand cmd1 = new MySqlCommand(sql1, mcon))
                {
                    
                    mcon.Open();
                    cmd1.Parameters.AddWithValue("@TecCMC", TecCMCText11.Text);
                    cmd1.Parameters.AddWithValue("@SutCMC",  SutCMCText11.Text);
                    cmd1.Parameters.AddWithValue("@MesCMC", MesCMCText11.Text);
                }
Как правильно построить запрос?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.01.2016, 13:24
Ответы с готовыми решениями:

Вход в учетную запись раз в сутки
Хочу ограничить ограничить время на пользование компьютером в гостевой учетке. Соответствующие программы легко обойти приостановкой...

Показывать popup только 1 раз в сутки или 1 раз в несколько часов
Здравствуйте, помогите разобраться Как сделать так, чтобы popup открывался только один раз в сутки или 1 раз в несколько часов Я не...

Как сделать автоматический back-up книги раз в неделю или раз в сутки
Ребят, помогите, у меня есть несколько вопросов 1. Как сделать автоматический back-up раз в неделю или раз в сутки и так чтобы файл...

5
 Аватар для kodv
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
26.01.2016, 04:00
Цитата Сообщение от NightWar Посмотреть сообщение
Как правильно построить запрос?
Если я правильно понял вашу проблему, то она заключается не в запросе, а в неверно спроектированной базе данных. Полей "Суточный" и "Месячный" не должно существовать в вашей таблице - они должны вычисляться на основании полей "Текущий" и "Дата" перед тем, как вы собираеетесь отобразить эту информацию пользователю.
0
6 / 6 / 3
Регистрация: 05.10.2015
Сообщений: 40
26.01.2016, 07:34  [ТС]
kodv, а можно поконкретней или ссылочку какую не будь что бы почитать

Добавлено через 3 минуты
kodv, я так понимаю это можно зделать оператором if
if (datetime.now.day = 1.day)
{
cmd1.Parameters.AddWithValue("@SutCMC", 0);
}
else
{
cmd1.Parameters.AddWithValue("@SutCMC", TecCMCText11.Text);
}

Добавлено через 28 минут
kodv, я не много нашёл и сейчас выглядит так :
C#
1
2
3
4
5
6
7
8
9
10
                    DateTime t1 = Convert.ToDateTime(DateTime.Now);
                    DateTime t2 = Convert.ToDateTime(("11:00 AM"));
                    if (t1.TimeOfDay.Ticks > t2.TimeOfDay.Ticks)
                    {
                        cmd1.Parameters.AddWithValue("@SutCMC", 0);
                    }
                    else
                    {
                        cmd1.Parameters.AddWithValue("@SutCMC", TecCMCText11.Text);
                    }
Но вот как в else сделать выборку с базы чтобы он заново начинал считать не пойму, что бы с 0 и потом опять пошёл считать, дай те пожалуйста умную мысль

Добавлено через 1 минуту
kodv, или можно по другому сбрасывать каждые сутки на 0 Текущее значение а потом приплюсовывать Месячные показание

Добавлено через 12 секунд
kodv, Я запутался (
0
 Аватар для kodv
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
26.01.2016, 07:47
Цитата Сообщение от NightWar Посмотреть сообщение
kodv, я так понимаю это можно зделать оператором if
Делайте. С таким подходом у вас поле SutCMC всегда будет иметь 0.

Добавлено через 1 минуту
Ух, как шустро добавляются записи в пост)
Цитата Сообщение от NightWar Посмотреть сообщение
дай те пожалуйста умную мысль
Уже же дал выше
Цитата Сообщение от kodv Посмотреть сообщение
Полей "Суточный" и "Месячный" не должно существовать в вашей таблице - они должны вычисляться на основании полей "Текущий" и "Дата" перед тем, как вы собираеетесь отобразить эту информацию пользователю.
Иначе вы все равно по итогу упретесь в тупик.
0
6 / 6 / 3
Регистрация: 05.10.2015
Сообщений: 40
26.01.2016, 07:54  [ТС]
kodv, Я так понимаю тогда делать тригером на самом mysql сервере? и не лезть в VS? а потом просто считывать значения в VS?
0
 Аватар для kodv
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
26.01.2016, 08:20
Цитата Сообщение от NightWar Посмотреть сообщение
делать тригером на самом mysql сервере
Что делать триггером?
Про что говорил я: у вас есть таблица с двумя полями: Дата и Количество калорий, которую вы и заполняете. Если вам нужно узнать количество калорий за текущий день, то вы пишите запрос:
T-SQL
1
SELECT SUM([Количество калорий]) FROM [Таблица] WHERE DATEDIFF(DAY, [Дата], CURRENT_TIMESTAMP) = 0
Елси нужно узнать количество калорий за текущий месяц, то:
T-SQL
1
SELECT SUM([Количество калорий]) FROM [Таблица] WHERE DATEDIFF(MONTH, [Дата], CURRENT_TIMESTAMP) = 0
. Если нужно нарастающим итогом с начала текущего месяца, как вы, скорее всего хотите сделать, то так:
T-SQL
1
SELECT *, (SELECT SUM([Количество калорий]) FROM [Таблица] WHERE DATEDIFF(DAY, [Дата], CURRENT_TIMESTAMP) = 0 AND [Дата] <= T.[Дата]) [С начала дня], (SELECT SUM([Количество калорий]) FROM [Таблица] WHERE DATEDIFF(MONTH, [Дата], CURRENT_TIMESTAMP) = 0 AND [Дата] <= T.[Дата]) [С начала месяца] FROM [Таблица] T WHERE DATEDIFF(MONTH, [Дата], CURRENT_TIMESTAMP)
Добавлено через 54 секунды
Код на T-SQL. Диалкет MySQL я не знаю. Если вас заинтересовало, то, думаю, вы сами сможете с T-SQL на MySQL перевести.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.01.2016, 08:20
Помогаю со студенческими работами здесь

Автоматическое изменения значения в базе данных раз в сутки
Здравствуйте! Столкнулся с такой проблемой. Есть сайт, написанный на джумле, на котором есть компонент галереи. В галерее реализована...

Введите с клавиатуры данные о температуре воздуха за месяц. Определите, сколько раз за месяц была самая низкая температура?
Собственно, проходим циклы, возникли проблемы с этой задачей. Нуждаюсь в вашей помощи.

Запрос раз в сутки
Понадобилось, что бы некая функция вызывалась когда системное время == 23:50 и 11:50. Как такое собственно сделать?

Выполнение скрипта 1 раз в сутки
Есть скрипт накрутки, мне надо что бы он для 1 ip выполнялся 1 раз в сутки. Что бы при обновлении страницы то что скрыто не исчезало! Если...

Обновить переменную раз в сутки
Как обновить переменную раз в сутки ,при входе программы?


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru