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

Обнуляются результаты голосования

10.09.2012, 09:51. Показов 828. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Такое дело:

На одном из сайтов попросили меня сделать фотоконкурс с голосованием. Я сделал и все работало нормально какое то время, но потом стало происходить непонятное обнуление некоторых результатов. То есть из 100 фоток например у 7шт результаты обнулились, но не стразу а как-то постепенно. Я могу только предположить что:

1. Так как посещаемость на время фотоконкурса выросла от 200-300 человек, до 2000-3000, база данных "глючит" и обнуляет иногда как то что то... (слабая версия на мой взгляд)
2. Иногда получается так, что два персонажа голосуют одновременно за одно и тоже фото, что вызывает когнитивный диссонанс у базы и она обнуляет значение

вот собственно обработчик:

PHP
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
<?php
    if (isset($_POST['vote'])) {$vote = $_POST['vote'];}
    if (isset($_POST['id_image'])) {$id_image = $_POST['id_image'];}
 
    $hostname = '1111';
    $username = '1111';
    $password = '1111';
 
    $db = mysql_connect($hostname, $username, $password) or die('connect to database failed');
    mysql_select_db('1111') or die('db not found');
 
 
    $ip = $_SERVER['REMOTE_ADDR']; 
    $r = mysql_query("SELECT * FROM vote_ip WHERE id_resp = '$id_image' AND ip = '$ip'");
    if(mysql_num_rows($r)==1) {echo "<br /><br /><br /><br /><p style='text-align:center'>С вашего IP уже был учтен голос <br /><a style='color:#990000' href=".$_SERVER["HTTP_REFERER"].">Вернуться</a></p>"; exit;}
 
    
    $date_resp = date("Y-m-d",time()+ 1*24*60*60); 
    mysql_query("INSERT INTO vote_ip (id_resp, ip, date_resp) VALUES ('$id_image','$ip','$date_resp')");
 
    $query = 'update Pictures set vote="'.$vote.'" where id="'.$id_image.'"';
    $result = mysql_query($query) or die('query failed');
    
    $day = date("Y-m-d H:i:s");
    mysql_query ("DELETE FROM vote_ip WHERE date_resp < '$day'");
 
    mysql_close($db); 
?>
 
    <br /><br /><br /><br /><div style="text-align:center">Спасибо за ваш голос!<br /> Чтобы завершить голосование пройдите по ссылке <br /><a style="color:#990000" href="<?php echo $_SERVER["HTTP_REFERER"]?>">Вернуться</a></div>
Подскажите кто, что знает...
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
10.09.2012, 09:51
Ответы с готовыми решениями:

При обновлений F5 не обнуляются переменные
Доброго времени суток При нажатии сабмит заносится строка а при обновлений по F5 опять происходит insert почему не обнуляются...

Cистема голосования
Приветствую разработчиков на PHP. у меня есть такой вопрос, как сделать такую систему голосования, чтобы выод результатов ьыл графическим,...

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

2
 Аватар для crautcher
2450 / 2301 / 597
Регистрация: 27.05.2011
Сообщений: 7,844
10.09.2012, 10:52
PHP
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
37
38
39
40
41
42
<?php
    #если нет перемнных зачем вообще чтото делать ?
    if (!isset($_POST['vote']) || isset(!$_POST['id_image']) ) 
     {
     echo "<br /><br /><br /><br /><p style='text-align:center'>возникла охибка , попробуйте проголосовать еще раз<br /><a style='color:#990000' href=".$_SERVER["HTTP_REFERER"].">Вернуться</a></p>"; 
     exit(0);
     }
     
    $hostname = '1111';
    $username = '1111';
    $password = '1111';  
    $db = mysql_connect($hostname, $username, $password) or die('connect to database failed');
    mysql_select_db('1111') or die('db not found'); 
     
    $vote = $_POST['vote'];
    #если айдишник число , то делаем его числом
    $id_image = intval($_POST['id_image']); 
 
    $ip = $_SERVER['REMOTE_ADDR']; 
    $r = mysql_query("SELECT * FROM vote_ip WHERE id_resp = '$id_image' AND ip = '$ip'");
    if(mysql_num_rows($r)==1) { 
      echo "<br /><br /><br /><br /><p style='text-align:center'>С вашего IP уже был учтен голос <br /><a style='color:#990000' href=".$_SERVER["HTTP_REFERER"].">Вернуться</a></p>";
      exit(0);
    }
     
    $date_resp = date("Y-m-d",time()+ 1*24*60*60); 
    mysql_query("INSERT INTO vote_ip (id_resp, ip, date_resp) VALUES ('$id_image','$ip','$date_resp')");
    #вот тут не понял что находится в переменной $vote ?
    #теоретически надо повышать рейтинг на 1 :
    # update Pictures set vote = vote + 1 where ...
    $query = 'update Pictures set vote="'.$vote.'" where id="'.$id_image.'"';
    $result = mysql_query($query) or die('query failed');
    
    $day = date("Y-m-d H:i:s");
    #зачем работайте с датой , если при проверки выше вы ее не учитывайте ?
    mysql_query ("DELETE FROM vote_ip WHERE date_resp < '$day'");
 
    mysql_close($db); 
?>
 
    <br /><br /><br /><br /><div style="text-align:center">Спасибо за ваш голос!<br />
     Чтобы завершить голосование пройдите по ссылке <br /><a style="color:#990000" href="<?php echo $_SERVER["HTTP_REFERER"]?>">Вернуться</a></div>
1
AlientAntFarm
10.09.2012, 14:31
Переделал, свой файл, должно помочь. Спасибо!
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
10.09.2012, 14:31
Помогаю со студенческими работами здесь

Написание голосования, проконсультируйте)
Здравствуйте. Вообщем нужно зделать опрос, чтоб пользователь голосовал за несколько пунктов (не знаю как правильно объяснить). Посмотрите...

Организация социального голосования на сайте
Аларм! Как всегда нужно вчера и срочно. Полгода назад задача была решена таким скриптом:...

Скрипт голосования с видимыми ответами
Кто знает скрипт голосования, чтобы уже во время голосования была видна статистика предыдущих голосов.

Сделать из голосования опрос. Задача на 1,2,3
Здравствуйте, уважаемые знатоки. Прошу сильно меня не пинать, я только учусь. Есть скрипт голосования, считает, выводит результаты и...

Настройка скрипта для голосования
Всем добрый день. Вот моя проблема. Пробую поставить уже пятый скрипт для голосования, и как можно догадаться, безуспешно. Вначале думал,...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
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
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru