3
include_once('../adodb.inc.php');
4
include_once('../adodb-active-record.inc.php');
6
// uncomment the following if you want to test exceptions
7
if (@$_GET['except']) {
8
if (PHP_VERSION >= 5) {
9
include('../adodb-exceptions.inc.php');
10
echo "<h3>Exceptions included</h3>";
14
$db = NewADOConnection('mysql://root@localhost/northwind?persist');
16
ADOdb_Active_Record::SetDatabaseAdapter($db);
19
$db->Execute("CREATE TEMPORARY TABLE `persons` (
20
`id` int(10) unsigned NOT NULL auto_increment,
21
`name_first` varchar(100) NOT NULL default '',
22
`name_last` varchar(100) NOT NULL default '',
23
`favorite_color` varchar(100) NOT NULL default '',
28
$db->Execute("CREATE TEMPORARY TABLE `children` (
29
`id` int(10) unsigned NOT NULL auto_increment,
30
`person_id` int(10) unsigned NOT NULL,
31
`name_first` varchar(100) NOT NULL default '',
32
`name_last` varchar(100) NOT NULL default '',
33
`favorite_pet` varchar(100) NOT NULL default '',
38
class Person extends ADOdb_Active_Record{ function ret($v) {return $v;} }
39
$person = new Person();
40
ADOdb_Active_Record::$_quoteNames = '111';
42
echo "<p>Output of getAttributeNames: ";
43
var_dump($person->getAttributeNames());
46
* Outputs the following:
51
* string(9) "name_first"
53
* string(8) "name_last"
55
* string(13) "favorite_color"
59
$person = new Person();
60
$person->name_first = 'Andi';
61
$person->name_last = 'Gutmans';
62
$person->save(); // this save() will fail on INSERT as favorite_color is a must fill...
65
$person = new Person();
66
$person->name_first = 'Andi';
67
$person->name_last = 'Gutmans';
68
$person->favorite_color = 'blue';
69
$person->save(); // this save will perform an INSERT successfully
71
echo "<p>The Insert ID generated:"; print_r($person->id);
73
$person->favorite_color = 'red';
74
$person->save(); // this save() will perform an UPDATE
76
$person = new Person();
77
$person->name_first = 'John';
78
$person->name_last = 'Lim';
79
$person->favorite_color = 'lavender';
80
$person->save(); // this save will perform an INSERT successfully
82
// load record where id=2 into a new ADOdb_Active_Record
83
$person2 = new Person();
84
$person2->Load('id=2');
86
$activeArr = $db->GetActiveRecordsClass($class = "Person",$table = "Persons","id=".$db->Param(0),array(2));
87
$person2 = $activeArr[0];
88
echo "<p>Name (should be John): ",$person->name_first, " <br> Class (should be Person): ",get_class($person2),"<br>";
90
$db->Execute("insert into children (person_id,name_first,name_last) values (2,'Jill','Lim')");
91
$db->Execute("insert into children (person_id,name_first,name_last) values (2,'Joan','Lim')");
92
$db->Execute("insert into children (person_id,name_first,name_last) values (2,'JAMIE','Lim')");
94
$newperson2 = new Person();
95
$person2->HasMany('children','person_id');
96
$person2->Load('id=2');
97
$person2->name_last='green';
98
$c = $person2->children;
101
if (is_array($c) && sizeof($c) == 3 && $c[0]->name_first=='Jill' && $c[1]->name_first=='Joan'
102
&& $c[2]->name_first == 'JAMIE') echo "OK Loaded HasMany</br>";
105
echo "error loading hasMany should have 3 array elements Jill Joan Jamie<br>";
108
class Child extends ADOdb_Active_Record{};
109
$ch = new Child('children',array('id'));
110
$ch->BelongsTo('person','person_id','id');
112
if ($ch->name_first !== 'Jill') echo "error in Loading Child<br>";
115
if ($p->name_first != 'John') echo "Error loading belongsTo<br>";
116
else echo "OK loading BelongTo<br>";
118
$p->hasMany('children','person_id');
119
$p->LoadRelations('children', " Name_first like 'J%' order by id",1,2);
120
if (sizeof($p->children) == 2 && $p->children[1]->name_first == 'JAMIE') echo "OK LoadRelations<br>";
121
else echo "error LoadRelations<br>";
123
$db->Execute("CREATE TEMPORARY TABLE `persons2` (
124
`id` int(10) unsigned NOT NULL auto_increment,
125
`name_first` varchar(100) NOT NULL default '',
126
`name_last` varchar(100) NOT NULL default '',
127
`favorite_color` varchar(100) default '',
132
$p = new adodb_active_record('persons2');
133
$p->name_first = 'James';
135
$p->name_last = 'James';
137
$p->HasMany('children','person_id');
b'\\ No newline at end of file'