Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770
Форумы портала PHP.SU :: Версия для печати :: Наверное сложный запрос Mysql
Форумы портала PHP.SU » PHP » SQL и Архитектура БД » Наверное сложный запрос Mysql

Страниц (1): [1]
 

1. Gokusq - 12 Апреля, 2011 - 21:16:17 - перейти к сообщению
Имеем таблицу базы
допустим такую

CODE (htmlphp):
скопировать код в буфер обмена
  1. $query="create table table1 (
  2.         id int(5) not null auto_increment,
  3.         Dohod float null,
  4.         Rashod float null,
  5.         Itog float null,
  6.         Data date,
  7.         primary key(id));";


поля доход ,расход вводим сами,а поле Itog необходимо посчитать в процессе.
причём считать нужно суммарный итог по всем записям.
т.е. типа так
CODE (SQL):
скопировать код в буфер обмена
  1. "insert into Table1 (Dohod,Data,Itog) values ($Dohod,'".$Year."-01-01',где Itog равен итог предыдущей записи + ДоходТекущей-РасходТекущей)";

Можно ли это сделать одним запросом?
И будет ли это работать быстрее чем если делать несколько запросов?
2. movEAX - 12 Апреля, 2011 - 21:52:39 - перейти к сообщению
Можно попробовать с помощью UPDATE, поподробней завтра напишу, если еще будет необходимость.
3. Gokusq - 12 Апреля, 2011 - 22:01:40 - перейти к сообщению
movEAX пишет:
Можно попробовать с помощью UPDATE, поподробней завтра напишу, если еще будет необходимость.

конечно пишите.
я тоже напишу если найду.
потом сравним.
4. movEAX - 13 Апреля, 2011 - 09:52:27 - перейти к сообщению
CODE (SQL):
скопировать код в буфер обмена
  1. SET @netto = 0;
  2. UPDATE  table1
  3. SET itog = (SELECT @netto:=@netto + dohod - rashod )
  4. ORDER BY id ASC;


PHP:
скопировать код в буфер обмена
  1. $mysqli = new mysqli('localhost', 'user', 'pass', 'dbname');
  2. $mysqli->query('SET @netto=0');
  3. $mysqli->query(
  4.    'UPDATE table1
  5.     SET itog = (SELECT @netto:=@netto + dohod - rashod)
  6.     ORDER BY id ASC'
  7. );


При условии, что данные свежевставлены и поле Itog во всех записях = Null

 

Powered by ExBB FM 1.0 RC1