Нужно хранить процедуру расчета по этим двум таблицам - PullRequest
0 голосов
/ 03 ноября 2018

Я должен сделать это в xampp, мне нужна структура sp для этого, так как я начинающий, если возможно, помогу дать полный sp для этого сценария с подробным объяснением. Другие структуры, такие как операции crud, были сделаны с помощью php, javascript

1. SELECT `cid`, `parent_cat`, `category_name`, `category_life`, `status` FROM `categories`
2. SELECT `pid`, `cid`, `bid`, `product_name`, `product_price`, `product_stock`, `added_date`, `p_status`, `loc`, `in_no`, `gst_no`, `cgst`, `sgst`, `igst`, `total`, `depre`, `pur_from` FROM `products` 

Из приведенных выше двух таблиц я должен получить запись, вычислить эти поля и вставить в таблицу ниже:

3. SELECT `elapsed_yend`, `remaining_days`, `depreciation_cur`, `current_wdv`, `depreciation_next`, `next_wdv`, `accumulate_depre`, `sale_amount`, `pro_los`, `end_date` FROM `calculation` 

Например, эти вычисления должны произойти в таблице продуктов:

CGST:
    cgst = product_price * 09
    sgst = product_price * 09
    igst = product_price * 09

if status is 1 it should calculate  igst other cgst,sgst must be 0(zero)
             0 it should calculate  cgst,sgst other igst  must be 0(zero)

        Depreciation Amount:

            depre = product_price + .5(cgst+sgst+igst)


Elapsede year end :
        elapsed_yend = added_date(from products table (No:2)) till every year 31/March/xxxx.

        Number of days between these two dates

    remaining_days = category_life - (date difference between added_date(from products (No:1)) till date)

    category_life(from categories table (No:1))Ex:mobile it's life will be 1080 days.

    Current Year depreciation:
        depreciation_cur  = (depre/category_life)*elapsed_yend

    Current Year Written down value:

        current_wdv  = depre - depreciation_cur

    Next Year depreciation :

        depreciation_next = (depre / category_life) * D
        D = days difference between every year 01/April/xxxx till end_date(from calculation table)

    Next Year Written down value:   

        next_wdv = current_wdv - depreciation_next

    Accumulate Depreciation :

        accumulate_depre = depreciation_cur + depreciation_next

1 Ответ

0 голосов
/ 13 ноября 2018

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

BEGIN
DECLARE cur_depre,cur_wtvalue,next_depre,next_wtvalue,accum_depre,pro_loss double(20,2);
DECLARE days,next_diff int;

CREATE TABLE IF NOT EXISTS calc AS (SELECT p.pid,p_date,days,next_diff,cur_depre,cur_wtvalue,next_depre,next_wtvalue,accum_depre,pro_loss,c.cid,p.added_date,c.category_life,p.depre,p.sale_status,p.sale_date,p.sale_amount from products p,products d,categories c WHERE p.pid=d.pid AND p.cid=c.cid 
 );
 INSERT INTO calc (PID) 
SELECT PID FROM products WHERE PID NOT IN (SELECT PID FROM calc);
UPDATE calc set days = datediff(p_date,added_date);
UPDATE calc set days = 0 WHERE datediff(p_date,added_date) < 0;
UPDATE calc set next_diff = datediff(sale_date,DATE_ADD(p_date, INTERVAL 1 DAY) );
UPDATE calc set next_diff = datediff('2019-03-31',added_date) WHERE added_date>p_date;
UPDATE calc set cur_depre = (depre/category_life)*datediff(p_date,added_date);

UPDATE calc set cur_depre = 0 where (depre/category_life)*datediff(p_date,added_date)<0;

UPDATE calc set cur_wtvalue =(depre-(depre/category_life)*datediff(p_date,added_date)); 

UPDATE calc set cur_wtvalue = 0 WHERE added_date>p_date;

UPDATE calc set next_depre =( (depre/category_life)*datediff(sale_date,DATE_ADD(p_date, INTERVAL 1 DAY) )) where added_date < p_date;

UPDATE calc set next_depre =( (depre/category_life) * datediff('2019-03-31',added_date)) WHERE added_Date > p_date;

UPDATE calc SET next_wtvalue = depre -(depre/category_life)*datediff(p_date,added_date) - (( (depre/category_life)*datediff(sale_date,DATE_ADD(p_date, INTERVAL 1 DAY) )) );
UPDATE calc SET next_wtvalue = depre - (( (depre/category_life) * datediff('2019-03-31',added_date)))  WHERE added_date>p_date;

UPDATE calc SET accum_depre = ((depre/category_life)*datediff(p_date,added_date))+( (depre/category_life)*datediff(sale_date,DATE_ADD(p_date, INTERVAL 1 DAY) )) ;
UPDATE calc SET accum_depre =( (depre/category_life) * datediff('2019-03-31',added_date))  WHERE added_Date > p_date;

UPDATE calc SET pro_loss = sale_amount-(depre -(depre/category_life)*datediff(p_date,added_date) - (( (depre/category_life)*datediff(sale_date,DATE_ADD(p_date, INTERVAL 1 DAY) )) ) ); 

UPDATE calc SET pro_loss = 0 WHERE sale_status=0;
SELECT * from calc;

END
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...