| |
|
|
| | Есть некая база MAGAZIN с таблицами DOGOVOR (поля - n_dogovor и summ) , PLATEJ (поля n_dog, summ_pl) и POSTAVKI (поля n_dogp, summ_p) Таблица DOGOVOR содержит информацию относительно номера договора и суммы, на которую заключен договор, таблица PLATEJ содержит договора, по которым произведена проплата и на какую сумму, POSTAVKI - соответственно, по какому договору на какую сумму была поставка.
Не могу никак въехать, как сделать разницу между платежами и поставками. Действовал по такому алгоритму :
1. Выбрать все договора :
<?php
$db = mysql_connect("localhost", "root");
mysql_select_db("magazin",$db);
$result = mysql_query("SELECT n_dogovor FROM magazin where 1",$db);
|
2. Просуммировал по каждому договору поставки и проплаты , вычел из проплаты
поставку, если сумма получается с плюсом - добовляю ее к переменной, если нет - следующий договор.
$saldo=0;
if ($myrow = mysql_fetch_array($result))
{
do
{
$summ_pl = mysql_query("SELECT sum(summ_pl) FROM platej where $myrow['n_dog']",$db);
$summ_post = mysql_query("SELECT sum(summ_p) FROM postavki where $myrow['n_dog']",$db);
if (( $summ_pl - $summ_post ) >0)
$summ_post + = $summ_pl - $summ_post ;
}
while ($myrow = mysql_fetch_array($result));
}
else
{
echo "Sorry, no records were found!";
}
?>
|
Дык вол именно этот кусок и не работает !
Помогите, кто знает в чем причина. Или хотя бы как просуммировать правильно по данному условию. Заранее благодарен ! | |
| |
|
|
| |
|
|
| |
для: Duran
(25.02.2005 в 08:46)
| | | Вы не может производить вычисление вот в этом блоке
if (( $summ_pl - $summ_post ) >0)
$summ_post + = $summ_pl - $summ_post ;
|
$summ_pl и $summ_post – это у вас ссылки на ресурсы, полученные запросом. Вам нужно получить из численное значение.
$summ_l = mysql_result($summ_pl,0)
$summ_2 = mysql_result($summ_post,0)
|
| |
| |
|
|
| |
|
|
| |
для: glsv (Дизайнер)
(25.02.2005 в 09:48)
| | | Спасибо %).
Кстати, проблема была не только в этом.
Может у кого-нибуть будут такие же грабли. Если использовать в PHP запрос вида:
select * from table where pole =$variable и $variable - есть символьная переменная, то ее нужно обрамить кавычками:
$zapros = "select * from table where pole ="."' "."$variable"."'"; | |
| |
|
|
| |
|
|
| |
для: Duran
(01.03.2005 в 15:52)
| | | >есть символьная переменная, то ее нужно обрамить кавычками:
Да, так и должно быть.
Можно написать чуточку проще.
<?
$zapros = "select * from table where pole ='$variable' ";
?>
|
| |
| |
|
|