49
|
1 package IMPL::ORM;
|
|
2 use strict;
|
|
3 use warnings;
|
|
4
|
|
5 use base qw(IMPL::Object);
|
|
6 use IMPL::Class::Property;
|
|
7 use Scalar::Util qw(weaken refaddr);
|
|
8
|
|
9 use IMPL::Exception;
|
|
10
|
|
11 our $Depth = 1; # загружать объект + 1 уровень детей
|
|
12 our $UseProxy = 1;
|
|
13
|
|
14 BEGIN {
|
|
15 private property _ObjectCache => prop_all;
|
|
16 private property _MapInstances => prop_all;
|
|
17 private property _WorkUnit => prop_all;
|
|
18 public property Schema => prop_all;
|
|
19 }
|
|
20
|
|
21 sub ObjectInfoById {
|
|
22 my ($this,$oid) = @_;
|
|
23
|
|
24 return $this->_ObjectCache->{$oid};
|
|
25 }
|
|
26
|
|
27 sub ObjectInfo {
|
|
28 my ($this,$inst) = @_;
|
|
29
|
|
30 die new IMPL::InvalidOperationException("This method can be used only for a reference") unless ref $inst;
|
|
31
|
|
32 return $this->_MapInstances->{refaddr $inst};
|
|
33 }
|
|
34
|
|
35
|
|
36 1;
|
|
37 __END__
|
|
38 =pod
|
|
39 =head1 SYNOPSIS
|
|
40
|
|
41 use IMPL::ORM::Sql;
|
|
42
|
|
43 my $DB = new IMPL::ORM::Sql("connection string");
|
|
44
|
|
45 local $IMPL::ORM::Depth = 1; # load childs only, no more
|
|
46
|
|
47 my $artist = $DB->Lookup( Artist => { name => 'Beatles' } );
|
|
48
|
|
49 my $order = new Order();
|
|
50 $order->AddItem($_) foreach $artist->Albums->List;
|
|
51
|
|
52 $DB->Save($order);
|
|
53
|
|
54 my $label = $artist->Albums->Index(0)->Label;
|
|
55
|
|
56 $DB->Populate($label); #load $label
|
|
57
|
|
58 =head1 DESCRIPTION
|
|
59 =head2 MEMBERS
|
|
60 =level 4
|
|
61 =back
|
|
62 =head2 Variables
|
|
63 =head2 INTERNALS
|
|
64 =head3 Object Representation
|
|
65
|
|
66 Каждый класс отображаемый в источник данных представляется в виде набора
|
|
67 сущностей, каждая из которых представляет состояние базового класса.
|
|
68
|
|
69 Foo entityFoo
|
|
70 Bar entityBar
|
|
71 Baz entityBaz
|
|
72
|
|
73 При сохранении виртуальных свойств классов в соответствующих сущностях заводится
|
|
74 два поля - одно под сохранение собственного значения свойства, другое - для
|
|
75 хренеия виртуального значения.
|
|
76
|
|
77 Foo
|
|
78 public virtual property Name => prop_all, {Type => String};
|
|
79
|
|
80 entityFoo
|
|
81 string m_Name - собственное значение
|
|
82 string v_Name - вртуальное значение
|
|
83
|
|
84 Каждый сохраненный объект в базе имеет собственный идентификатор.
|
|
85 Новые объекты идентификатора не имеют, до тех пор пока они не будут сохранены.
|
|
86
|
|
87 =head3 Object Cache
|
|
88
|
|
89 Для учета объектов, которые присутствуют в источнике данных используется кеш
|
|
90 объектов. Сюда попадают полученные из базы объекты, а также вновь добавленные
|
|
91 объекты.
|
|
92
|
|
93 ObjectInfo => {
|
|
94 instance => weak ref
|
|
95 _id => data source dependent id
|
|
96 state => {persistent|null|new|deleted}
|
|
97 work_unit => ref to the work unit where object is acting
|
|
98 }
|
|
99
|
|
100 данная структура доступна через две функции ObjectInfoById и ObjectInfo
|
|
101
|
|
102 =head3 Type mapping
|
|
103
|
|
104 Источник данных имеет в себе схему данных, которая определяет набор типов,
|
|
105 хранимых в данном источнике. Есть несколько видов отображения типов:
|
|
106
|
|
107 =level 4
|
|
108
|
|
109 =item 1
|
|
110
|
|
111 Отображение классов, когда класс рассмаривается в иде набора свойств
|
|
112
|
|
113 =item
|
|
114
|
|
115 Отображение классов в одно значение (напрмер строку, данные и т.п.)
|
|
116
|
|
117 =item
|
|
118
|
|
119 Классы, которые на прямую работают с источником данных, такие как коллекции.
|
|
120
|
|
121 =back
|
|
122
|
|
123 =cut
|