Ben (bana!) Beklenmeyen bir davranış alıyorum Symfony 1.4 ile bir-çok ilişkisi tanımlarken. İşte bir İşveren tablosu ve Çalışan tablo olan, davranışı gösteren basit bir örnek: Bir İşveren birçok çalışanlar olabilir. Aşağıdaki gibi YML şema dosyası:
Employee:
columns:
id: { type: integer, primary: true, autoincrement: true }
first_name: { type: string(30), notnull: true }
last_name: { type: string(30), notnull: true }
employer_id: { type: integer }
relations:
Employer:
local: employer_id
foreign: id
type: one
foreignType: many
foreignAlias: Workers
Employer:
columns:
id: { type: integer, primary: true, autoincrement: true }
name: { type: string(100) }
line1: { type: string(100) }
city: { type: string(100) }
state: { type: string(10) }
Böylece, bir İşveren üzerindeki getWorkers()
çağırarak işverene w / ilişkili Çalışanlar dönmelidir. I getWorkers()
ilk kez olarak adlandırılan bu beklenen davranışı olsun.
Ek çalışanlar işveren (ya programlı veya doğrudan DB [MySQL]) eklenmiştir Ancak, sonraki aramalarda, getWorkers()
çağrı hala ilk sonuçları döndürür.
Ben için Symfony kaynak üzerinden atlama tarafından doğrulandı getWorkers()
, sonraki aramalarda, o _references
dizide saklanan önbelleğe alınan değer döndüren oluyor diyoruz.
Ben programlı yabancı anahtarı izlerseniz, Employee
employee_id
, sonra tam sonuç kümesi olsun tarafından sorgulanıyor.
Herkes bu davranış açıklayabilir misiniz?
İşte davranışı gösterir bir 'eylem', çalıştırmak bazı örnek PHP kod:
// Create common employer.
$employer = new Employer();
$employer->setName("My Employer");
$employer->setLine1("100 Main Street");
$employer->setCity("AnyTown");
$employer->setState("State");
$employer->save();
// Create two employees,
$worker1 = new Employee();
$worker1->setFirstName("John");
$worker1->setLastName("Doe");
$worker1->setEmployer($employer);
$worker1->save();
$worker2 = new Employee();
$worker2->setFirstName("Jane");
$worker2->setLastName("Smith");
$worker2->setEmployer($employer);
$worker2->save();
$myEmployer = Doctrine_Core::getTable('Employer')->findOneBy('name', 'My Employer');
$workers = $myEmployer->getWorkers();
echo "Number of workers for " . $myEmployer->getName() . ' is ' . count($workers);
// This gives the expected 2 employees.
// Now create another employee in the common employer.
$worker3 = new Employee();
$worker3->setFirstName("Anne");
$worker3->setLastName("Droid");
$worker3->setEmployer($employer);
$worker3->save();
$myEmployer = Doctrine_Core::getTable('Employer')->findOneBy('name', 'My Employer');
$workers = $myEmployer->getWorkers();
echo "Number of workers for " . $myEmployer->getName() . ' is ' . count($workers);
// This still gives 2 employees, whereas there are 3 in the DB.
// Follow FK directly.
$workers = Doctrine_Core::getTable('Employee')->findBy('employer_id', $myEmployer->getId());
echo "Number of workers for " . $myEmployer->getName() . ' is ' . count($workers);
// This gives the expected 3 employees.
Nasıl bu ilişki, her zaman yeniden takip kuvvet?