Doctrine 1.2模型使用Zend Framework和MySQL 5将整数字段作为字符串值返回

时间:2010-12-19 18:15:30

标签: mysql zend-framework types doctrine-1.2

我知道为什么我的Doctrine 1.2模型会为整数定义的字段返回 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
    // ...
}

示例控制器代码:

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)

任何想法,非常感谢。 ; - )

2 个答案:

答案 0 :(得分:3)

另外作为下面的答案,对左侧和右侧字符串的按位操作将对ASCII值进行操作。

您可以使用水合侦听器将int转换为int。创建一个新的水合侦听器并将其添加到记录(1),或者只使用记录对象中的现有钩子模板(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;       
    }
}

答案 1 :(得分:0)

这不是在PHP中使用无类型变量的好处吗?这造成了什么问题?如果需要,您仍然可以对其进行数学运算。虽然,我怀疑你不需要对除字符串比较之外的用户ID做任何操作。