/var/www/(Del)gepgroup.hk/php-activerecord/examples/orders/orders.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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
<?php
require_once __DIR__ '/../../ActiveRecord.php';

// initialize ActiveRecord
ActiveRecord\Config::initialize(function($cfg)
{
    
$cfg->set_model_directory(__DIR__ '/models');
    
$cfg->set_connections(array('development' => 'mysql://test:test@127.0.0.1/orders_test'));

    
// you can change the default connection with the below
    //$cfg->set_default_connection('production');
});

// create some people
$jax = new Person(array('name' => 'Jax''state' => 'CA'));
$jax->save();

// compact way to create and save a model
$tito Person::create(array('name' => 'Tito''state' => 'VA'));

// place orders. tax is automatically applied in a callback
// create_orders will automatically place the created model into $tito->orders
// even if it failed validation
$pokemon $tito->create_orders(array('item_name' => 'Live Pokemon''price' => 6999.99));
$coal    $tito->create_orders(array('item_name' => 'Lump of Coal''price' => 100.00));
$freebie $tito->create_orders(array('item_name' => 'Freebie''price' => -100.99));

if (
count($freebie->errors) > 0)
    echo 
"[FAILED] saving order $freebie->item_name: " join(', ',$freebie->errors->full_messages()) . "\n\n";

// payments
$pokemon->create_payments(array('amount' => 1.99'person_id' => $tito->id));
$pokemon->create_payments(array('amount' => 4999.50'person_id' => $tito->id));
$pokemon->create_payments(array('amount' => 2.50'person_id' => $jax->id));

// reload since we don't want the freebie to show up (because it failed validation)
$tito->reload();

echo 
"$tito->name has " count($tito->orders) . " orders for: " join(', ',ActiveRecord\collect($tito->orders,'item_name')) . "\n\n";

// get all orders placed by Tito
foreach (Order::find_all_by_person_id($tito->id) as $order)
{
    echo 
"Order #$order->id for $order->item_name ($$order->price + $$order->tax tax) ordered by " $order->person->name "\n";

    if (
count($order->payments) > 0)
    {
        
// display each payment for this order
        
foreach ($order->payments as $payment)
            echo 
"  payment #$payment->id of $$payment->amount by " $payment->person->name "\n";
    }
    else
        echo 
"  no payments\n";

    echo 
"\n";
}

// display summary of all payments made by Tito and Jax
$conditions = array(
    
'conditions'    => array('id IN(?)',array($tito->id,$jax->id)),
    
'order'            => 'name desc');

foreach (
Person::all($conditions) as $person)
{
    
$n count($person->payments);
    
$total array_sum(ActiveRecord\collect($person->payments,'amount'));
    echo 
"$person->name made $n payments for a total of $$total\n\n";
}

// using order has_many people through payments with options
// array('people', 'through' => 'payments', 'select' => 'people.*, payments.amount', 'conditions' => 'payments.amount < 200'));
// this means our people in the loop below also has the payment information since it is part of an inner join
// we will only see 2 of the people instead of 3 because 1 of the payments is greater than 200
$order Order::find($pokemon->id);
echo 
"Order #$order->id for $order->item_name ($$order->price + $$order->tax tax)\n";

foreach (
$order->people as $person)
    echo 
"  payment of $$person->amount by " $person->name "\n";
?>