我正在开发Php Phalcon,Xampp服务器。我的模特班是继承人。
我有一个UsersAbstract类,它有一些通用属性,如全名、电子邮件ID等。
然后我派生了一个类userofficer,这个类有更多的属性,比如职业等,然后我有一个孙子类(继承自userofficer),叫做officerdoctor。
UsersAbstract类也是UserPatients的父类。
当我想访问UsersAbstract和UserPatients时,我使用了以下代码:
$select_patient = "Select "
."UserPatients.Patient_ID, "
."UserPatients.Unique_ID, "
."UsersAbstract.Full_Name, "
."UsersAbstract.Age, "
."UsersAbstract.Gender, "
."UsersAbstract.City, "
."UsersAbstract.Country FROM UserPatients JOIN UsersAbstract WHERE UsersAbstract.Unique_ID = UserPatients.Unique_ID "
."And UsersAbstract.Availablity_Flag = 1";
$patients = $this->modelsManager->executeQuery($select_patient);
$this->current_patient = $patients[0];
这很管用。现在我想从userofficers访问一个属性,下面是我的代码:
$id = $user->Unique_ID;
$select_doctor = "Select UserOfficials.Occupation from UserOfficials WHERE UserOfficials.Unique_ID = :uid:";
$occ = $this->modelsManager->executeQuery($select_doctor, array("uid" => $id));
此代码给出以下错误:
SQLSTATE[42S22]: Column not found: 1054 Unknown column 'usersabstract.Occupation' in 'field list'
我的问题很简短-为什么?我正在访问表userofficers而不是UsersAbstract。
注:
我的表和相应的类命名如下:
Class -------------- Table
UsersAbstract ------ UsersAbstract
UserOfficials ------ User_Officials
UserPatients ------- User_Patients
我知道对应数据库表的camel大小写名称必须是,但是如果一个查询有效,那么为什么另一个查询不行呢?
最佳答案
我已经解决了这个问题,我不得不在列的名称周围加上单引号。$select_doctor = "Select UserOfficials.Occupation from UserOfficials WHERE UserOfficials.Unique_ID = :uid:"
;
在这之后,它没有再出现错误。