知道为什么我的 Doctrine 1.2 模型会为 integer 定义的字段返回 string 值吗?
基本模型定义为:
abstract class Kwis_Model_Base_User extends Doctrine_Record
{
public function setTableDefinition()
{
$this->setTableName('user');
$this->hasColumn('id', 'integer', 4, array(
'unsigned' => true,
'primary' => true,
'autoincrement' => true,
));
// more fields
// ...
}
表模型定义为:
class Kwis_Model_UserTable extends Kwis_Model_BaseTable
{
/**
* Returns an instance of this class.
*
* @return object Kwis_Model_UserTable
*/
public static function getInstance()
{
$table = Doctrine_Core::getTable('Kwis_Model_User');
return $table;
}
// other methods
// ...
}
示例 Controller 代码:
class TestController extends Zend_Controller_Action
{
public function indexAction()
{
$userTable = Kwis_Model_UserTable::getInstance();
$user = $userTable->find(1);
echo "<pre>" . var_dump($user->id) . "</pre>"; die();
}
}
产生的输出:
string '1' (length=1)
任何想法,非常感谢。 ;-)
最佳答案
同时作为对以下问题的回答,对字符串左侧和右侧的按位运算将对 ASCII 值进行运算。
您可以使用 hydration 监听器将 int 转换为 int。要么创建一个新的 hydration listener 并将其添加到 record(1),要么只使用 record 对象中现有的钩子(Hook)模板(2)。
1:http://www.doctrine-project.org/projects/orm/1.2/docs/manual/event-listeners/pl#record-listeners
2:
abstract class My_Rec extends Doctrine_Record {
function postHydrate($event) {
$data = $event->data;
$data['status'] = (int) $data['status'];
$event->data = $data;
}
}
关于mysql - Doctrine 1.2 模型使用 Zend Framework 和 MySQL 5 将整数字段返回为字符串值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4484385/