Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
Программирование. Ступени успешной карьеры. Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель MySQL 5. Авторы: Кузнецов М.В., Симдянов И.В. MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель PHP 5 / 6 (3 издание). Авторы: Кузнецов М.В., Симдянов И.В. PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: MySql, не сбрасывается содержимое таблицы на диск...
 
 автор: VitoMorpheus   (11.07.2005 в 21:13)   письмо автору
 
 

Пишем рпг веб игруху.
Кусок скрипта боя.
if ($attack==1) {
$mana1=$mana1-$strength1; //при ударе собственная мана уменьшается
if ($defend2<>1 AND $defend2<>4) {
$life2=$life2-$strength1; // уровень жизни противника уменьшается
$result=mysql("phpopenchat","UPDATE chat_data SET life='".$life2."' WHERE Nick='".$username2."'") or die(mysql_errno().mysql_error());
$result=mysql_query("FLUSH TABLES");
sleep(5);
};
$result=mysql("phpopenchat","UPDATE chat_data SET mana='".$mana1."' WHERE Nick='".$username1."'") or die(mysql_errno().mysql_error());
$result=mysql_query("FLUSH TABLES");
sleep(0);
};
Команда Flush Tables не срабатывает - запись на диск измененного значения mana1 и life2 не происходит. Иногда бывало помогала небольшая задержка во времени sleep(3) или около того, но потом вообще перестало срабатывать.
Подскажите кто что знает, заранее спасибо!

   
 
 автор: cheops   (12.07.2005 в 00:20)   письмо автору
 
   для: VitoMorpheus   (11.07.2005 в 21:13)
 

Велика ли таблица chat_data и какой её тип?

PS Вопросы посвящённые MySQL лучше сразу помещать в соответствующем разделе http://www.softtime.ru/forum/index.php?id_forum=3

   
 
 автор: VitoMorpheus   (12.07.2005 в 13:02)   письмо автору
 
   для: cheops   (12.07.2005 в 00:20)
 

Таблица имеет тип MyISAM. Структура таблицы содержит 32 поля. В таблице всего 2 записи (3016 Байт). Таблица chat_data однажды, еще до написания неработающего скрипта, была испорчена из-за неожиданного отключения питания и ремонтировалась с помощью phpMyAdmin (Repair). Может быть поэтому она глючит? Но я пытался скопировать структуру и данные chat_data в другую таблицу, которую затем переименовал в chat_data. Это не помогло.
Данный скрипт используется на localhost при одновременной работе двух пользователей (имитация боя) - запущено две копии Internet Explorer. Может быть, сброс таблиц на диск одним пользователем блокирует сброс таблиц другим пользователем на время? Но глюки были таковы, что иногда записывалось новое значение life и не записывалось новое значение mana, или наоборот, в зависимости от вставки промежуточных команд sleep(). sleep() перестала помогать после удаления из таблицы четырех записей (раньше там было 6 записей).

   
 
 автор: cheops   (12.07.2005 в 13:18)   письмо автору
 
   для: VitoMorpheus   (12.07.2005 в 13:02)
 

А таблица на момент записи блокируется при помощи LOCK TABLE? Вообще говоря странно, что такие проблемы при такой маленькой таблице и такой маленькой нагрузке...

   
 
 автор: VitoMorpheus   (13.07.2005 в 09:22)   письмо автору
 
   для: cheops   (12.07.2005 в 13:18)
 

Нет, блокировка при помощи LOCK TABLE не используется.

   
 
 автор: cheops   (13.07.2005 в 11:48)   письмо автору
 
   для: VitoMorpheus   (13.07.2005 в 09:22)
 

Может попробовать использовать её - в этом случае запрос будет ждать до тех пор, пока не отработает первый запрос.

   
 
 автор: VitoMorpheus   (15.07.2005 в 11:30)   письмо автору
 
   для: cheops   (13.07.2005 в 11:48)
 

Блокировка таблицы не помогает. Новые значения life, mana в таблицу не записываются.

if ($attack==1) {
$mana1=$mana1-$strength1; //при ударе собственная мана уменьшается
if ($defend2<>1 AND $defend2<>4) {
$life2=$life2-$strength1; // уровень жизни противника уменьшается

$result=mysql("phpopenchat","LOCK TABLES chat_data WRITE");
$result=mysql("phpopenchat","UPDATE chat_data SET life='".$life2."' WHERE Nick='".$username2."'") or die(mysql_errno().mysql_error());
$result=mysql_query("FLUSH TABLES");
$result=mysql("phpopenchat","UNLOCK TABLES");


};
$result=mysql("phpopenchat","LOCK TABLES chat_data WRITE");
$result=mysql("phpopenchat","UPDATE chat_data SET mana='".$mana1."' WHERE Nick='".$username1."'") or die(mysql_errno().mysql_error());
$result=mysql_query("FLUSH TABLES");
$result=mysql("phpopenchat","UNLOCK TABLES");


};

С помощью phpMyAdmin эту же таблицу легко можно редактировать (при этом внесенные изменения сохраняются в таблице). А скрипт почему-то не работает.

   
 
 автор: cheops   (15.07.2005 в 13:09)   письмо автору
 
   для: VitoMorpheus   (15.07.2005 в 11:30)
 

Хм... а версия сервера MySQL какая?

   
 
 автор: VitoMorpheus   (15.07.2005 в 19:56)   письмо автору
 
   для: cheops   (15.07.2005 в 13:09)
 

Используется mysql-3.23.34 в составе пакета phpdev4 (Apache, PHP4, mysql) в Windows-98 (в Windows XP этот набор почему-то не работает). Пакет старенький, еще 2001 года выпуска.

   
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования